

# **MIPI User Guide**

Issue 04

Date 2019-09-12

#### Copyright © HiSilicon (Shanghai) Technologies Co., Ltd. 2019. All rights reserved.

No part of this document may be reproduced or transmitted in any form or by any means without prior written consent of HiSilicon (Shanghai) Technologies Co., Ltd.

#### **Trademarks and Permissions**

(HISILICON), and other HiSilicon icons are trademarks of HiSilicon Technologies Co., Ltd.

All other trademarks and trade names mentioned in this document are the property of their respective holders.

#### **Notice**

The purchased products, services and features are stipulated by the contract made between HiSilicon and the customer. All or part of the products, services and features described in this document may not be within the purchase scope or the usage scope. Unless otherwise specified in the contract, all statements, information, and recommendations in this document are provided "AS IS" without warranties, guarantees or representations of any kind, either express or implied.

The information in this document is subject to change without notice. Every effort has been made in the preparation of this document to ensure accuracy of the contents, but all statements, information, and recommendations in this document do not constitute a warranty of any kind, express or implied.

# HiSilicon (Shanghai) Technologies Co., Ltd.

Address: New R&D Center, 49 Wuhe Road, Bantian,

Longgang District,

Shenzhen 518129 P. R. China

Website: http://www.hisilicon.com/en/

Email: support@hisilicon.com



# **About This Document**

# **Related Versions**

The following table lists the product versions related to this document.

| Product Name | Version |
|--------------|---------|
| Hi3559A      | V100ES  |
| Hi3559A      | V100    |
| Hi3559C      | V100    |
| Hi3519A      | V100    |
| Hi3556A      | V100    |
| Hi3516D      | V300    |
| Hi3516C      | V500    |
| Hi3516A      | V300    |
| Hi3559       | V200    |
| Hi3556       | V200    |
| Hi3516E      | V200    |
| Hi3516E      | V300    |
| Hi3518E      | V300    |
| Hi3516D      | V200    |





#### M NOTE

- Unless otherwise stated, Hi3559C V100 and Hi3559A V100 contents are consistent.
- Unless otherwise stated, Hi3556A V100 and Hi3519A V100 contents are consistent.
- Unless otherwise stated, Hi3516D V300, Hi3559 V200, Hi3556 V200, Hi3516A V300, and Hi3516C V500 contents are consistent.

# **Intended Audience**

This document is intended for:

- Technical support engineers
- Software development engineers

# **Symbol Conventions**

The symbols that may be found in this document are defined as follows.

| Symbol                 | Description                                                                                                                                                                                                                               |
|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>▲ DANGER</b>        | Indicates an imminently hazardous situation which, if not avoided, will result in death or serious injury.                                                                                                                                |
| <b><u>∧</u>WARNING</b> | Indicates a potentially hazardous situation which, if not avoided, could result in death or serious injury.                                                                                                                               |
| <b>∆CAUTION</b>        | Indicates a potentially hazardous situation which, if not avoided, may result in minor or moderate injury.                                                                                                                                |
| NOTICE                 | Indicates a potentially hazardous situation which, if not avoided, could result in equipment damage, data loss, performance deterioration, or unanticipated results.  NOTICE is used to address practices not related to personal injury. |
| NOTE                   | Calls attention to important information, best practices and tips.  NOTE is used to address information not related to personal injury, equipment damage, and environment deterioration.                                                  |

# **Change History**

Changes between document issues are cumulative. The latest document issue contains all changes made in previous issues.

#### Issue 04 (2019-09-12)

This issue is the fourth official release, which incorporates the following changes:



MIPI User Guide About This Document

In section 1.3, Table 1-4 and Table 1-5 are modified.

Section 1.4 is modified.

In section 1.5, the **Note** field of mipi\_dev\_attr\_t is modified.

#### Issue 03 (2019-08-01)

This issue is the third official release, which incorporates the following changes:

In section 1.4, the **Note** field of HI\_MIPI\_SET\_HS\_MODE is modified.

Section 1.6 "Parameter of the MIPI TX Module" is added.

#### Issue 02 (2019-06-20)

This issue is the second official release, which incorporates the following changes:

In section 1.4, the **Note** fields of HI\_MIPI\_TX\_ENABLE, HI\_MIPI\_SET\_PHY\_CMVMODE, and HI\_MIPI\_TX\_ENABLE are updated.

In section 1.5, the **Syntax** field of data\_type\_t is updated. The **Member** fields of sync\_info\_t, combo\_dev\_cfg\_t, and cmd\_info\_t are updated.

Section 1.7 is updated.

#### Issue 01 (2019-05-20)

This issue is the first official release, which incorporates the following changes:

In section 1.5, the description in the **Note** field of input\_mode\_t is modified.

Section 1.6 is modified

#### Issue 00B16 (2019-04-15)

This issue is the sixteenth draft release, which incorporates the following changes:

The support for the Hi3516D V200 chip is added.

In section 1.4, HI\_MIPI\_TX\_GET\_CMD is added.

In section 1.5, get\_cmd\_info\_t, slvs\_err\_check\_mode\_t, mipi\_clk\_mode\_t, lvds\_lane\_work\_mode\_t, lvds\_lane\_work\_attr\_t, and lvds\_dev\_attr\_ex\_t are added. input\_mode\_t, data\_type\_t, data\_type\_t, slvs\_dev\_attr\_t, and combo\_dev\_attr\_t are updated.

Section 1.6 is updated.

#### Issue 00B15 (2019-02-28)

This issue is the fifteenth draft release, which incorporates the following changes:

The support for the Hi3516A V300 chip is added.

Section 1.6 is modified

#### Issue 00B14 (2019-01-15)

This issue is the fourteenth draft release, which incorporates the following changes:

In section 1.3, Table 1-2 is modified.



MIPI User Guide About This Document

In section 1.5, the descriptions in the **Chip Difference** field of mipi\_data\_rate\_t and the **Note** field of mipi\_dev\_attr\_t are modified.

#### Issue 00B13 (2018-11-13)

This issue is the thirteenth draft release, which incorporates the following changes:

The content related to Hi3518E V300 is added.

In section 1.5, WDR\_VC\_NUM, SYNC\_CODE\_NUM, wdr\_mode\_t, video\_mode\_t, cmd\_info\_t, and mipi\_dev\_attr\_t are updated.

In section 1.6, the **Parameter Description** field below Figure 1-5 is updated.

#### Issue 00B12 (2018-10-30)

This issue is the twelfth draft release, which incorporates the following changes:

The description of Hi3516E V200/Hi3516E V300 is added.

#### Issue 00B11 (2018-10-15)

This issue is the eleventh draft release, which incorporates the following changes:

In section 1.5, WDR\_VC\_NUM and wdr\_mode\_t are modified.

Section 1.6 is modified.

#### Issue 00B10 (2018-09-29)

This issue is the tenth draft release, which incorporates the following changes:

The description of Hi3559 V200/Hi3556 V200 is added.

#### Issue 00B09 (2018-09-04)

This issue is the ninth draft release, which incorporates the following changes:

The description of Hi3516C V500/Hi3516D V300 is added.

#### Issue 00B08 (2018-08-08)

This issue is the eighth draft release, which incorporates the following changes:

In section 1.6, the description of Hi3519A V100 proc information is added.

#### Issue 00B07 (2018-07-06)

This issue is the seventh draft release, which incorporates the following changes:

In section 1.5, the description in the **Syntax** field of WDR\_VC\_NUM is modified.

Section 1.6 is modified.

#### Issue 00B06 (2018-05-15)

This issue is the sixth draft release, which incorporates the following changes:

In section 1.5, the descriptions in the **Note** field of img\_rect\_t and the **Member** field of slvs\_dev\_attr\_t are modified.



MIPI User Guide About This Document

In section 1.4, HI\_MIPI\_CLEAR is added. The description in the **Note** field of HI\_MIPI\_SET\_DEV\_ATTR is modified.

In section 1.5, COMS\_MAX\_DEV\_NUM is added. The descriptions in the **Definition** and **Note** fields of input\_mode\_t are modified.

#### Issue 00B05 (2018-04-28)

This issue is the fifth draft release, which incorporates the following changes:

The descriptions about the Hi3519A V100 are added.

In section 1.4, HI\_MIPI\_TX\_SET\_DEV\_CFG, HI\_MIPI\_TX\_SET\_CMD, and HI MIPI TX ENABLE are added.

In section 1.5, HI\_MIPI\_TX\_IOC\_MAGIC to cmd\_info\_t are added.

#### Issue 00B04 (2018-01-15)

This issue is the fourth draft release, which incorporates the following changes:

The descriptions about the Hi3559A V100 and Hi3559C V100 are added.

#### Issue 00B03 (2017-09-20)

This issue is the third draft release, which incorporates the following changes:

In section 1.4, HI\_MIPI\_SET\_OUTPUT\_MSB is deleted. The description in the **Definition** field of HI\_MIPI\_DISABLE\_SENSOR\_CLOCK is modified.

In section 1.5, SYNC\_CODE\_NUM, wdr\_mode\_t, lvds\_sync\_mode\_t, lvds\_bit\_endian\_t, lvds\_vsync\_type\_t, lvds\_vsync\_attr\_t, lvds\_fid\_type\_t, lvds\_fid\_attr\_t, lvds\_dev\_attr\_t and slvs\_dev\_attr\_t are added. data\_rate\_t is renamed to mipi\_data\_rate\_t and the descriptions in its **Definition** field are modified. The contents related to phy\_cmv\_mode\_t and combo dev attr\_t are modified. output msb\_t is deleted.

combo\_dev\_t, sns\_rst\_source\_t, and sns\_clk\_source\_t are modified.

In section 1.6, the descriptions in the **Debugging Information** and **Parameter Description** fields are modified.

#### Issue 00B02 (2017-07-20)

This issue is the second draft release, which incorporates the following changes:

In section 1.3, table 1-2 is modified.

#### Issue 00B01 (2017-06-14)

This issue is the first draft release.



# **Contents**

| About This Document                                                              | i   |
|----------------------------------------------------------------------------------|-----|
| 1 Introduction                                                                   |     |
| 1.1 Overview                                                                     |     |
| 1.2 Important Concepts                                                           | 1   |
| 1.3 Function Description                                                         |     |
| 1.4 API Reference                                                                |     |
| 1.5 Data Structures                                                              |     |
| 1.6 Parameter of the MIPI TX Module                                              | 69  |
| 1.7 Proc Information                                                             | 70  |
| 1.7.1 MIPI_RX Proc Information                                                   |     |
| 1.7.2 MIPI_TX Proc Information                                                   |     |
| 1.8 FAQs                                                                         |     |
| 1.8.1 How Do I Configure a Lane ID?                                              | 104 |
| 1.8.2 What Is the Relationship Between the MIPI Lane Frequency and VI Frequency? | 105 |



# **Figures**

| Figure 1-1 SOF/EOF/SOL/EOL sync mode | 2  |
|--------------------------------------|----|
| Figure 1-2 SAV/EAV sync mode         | 3  |
| Figure 1-3 MIPI data stream.         | 73 |
| Figure 1-4 MIPI data stream.         | 83 |
| Figure 1-5 MIPI data stream.         | 92 |
| Figure 1-6 MIPI data stream.         | 98 |



# **Tables**

| Table 1-1 Maximum number of lanes                                    | 3        |
|----------------------------------------------------------------------|----------|
| Table 1-2 Maximum number of sensors                                  |          |
| Table 1-3 MIPI RX lane distribution mode                             | 2        |
| Table 1-4 Maximum number of lanes                                    | <i>6</i> |
| Table 1-5 Lane multiplexing relationship between MIPI RX and SLVS-EC | <i>6</i> |
| Table 1-6 LVDS sync mode                                             | 50       |
| Table 1-7 Mapping between the sensor and MIPI RX pins                | 104      |



# $\mathbf{1}$ Introduction

# NOTICE

- Hi3516E V300, Hi3518E V300, Hi3516D V200, and Hi3516E V200 do not support MIPI TX.
- Unless otherwise specified, the descriptions of Hi3516D V200 and Hi3516E V300 are the same, and the descriptions of Hi3518E V300 and Hi3516E V200 are the same.

# 1.1 Overview

The mobile industry processor interface (MIPI) RX module receives raw video data by using low-voltage differential signals, converts the received serial differential signals into digital camera (DC) timings, and then transmit the timings to the downstream video capture (VICAP) module.

The MIPI RX supports the MIPI D-PHY, LVDS, and high-speed serial pixel interface (HiSPi) serial video signal inputs and is compatible with the DC video interface.

The SLVS-EC interface is defined by SONY and used for capturing images with high frame rate and resolution. The interface can convert the high-speed serial data into the digital camera timing and transfers it to the downstream VICAP module.

The SLVS-EC serial video interface provides higher transmission bandwidth, lower power consumption, and lower data redundancy in packaging mode. The SLVS-EC interface provides more reliable and stable transmission in application.

# 1.2 Important Concepts

• MIPI

The MIPI described in this document refers to the communications interface which uses the D-PHY transmission specifications at the physical layer and CSI-2 at the protocol layer.

LVDS



The low-voltage differential signaling (LVDS) technology differentiates blanking regions and valid data by using the sync code.

#### SLVS-EC

The scalable low voltage signaling embedded clock (SLVS\_EC) is an interface paralleled to the MIPI interface and used for capturing images with high frame rate and resolution.

#### Lane

A lane is a high-speed differential pair for connecting the TX end and RX end. It can be a clock lane or a data lane.

#### Link

A link consists of a clock lane and at least one data lane between the TX end and RX end. In this document, link is a software concept, and each link contains two data lanes.

#### Sync code

The MIPI interface uses the short packet in CSI-2 for synchronization, and the LVDS uses the sync code to differentiate valid data and blanking regions. There are two sync modes for the LVDS:

SOF and EOF indicate the start and end of a frame respectively, and SOL and EOL indicate the start and end of a line respectively. Figure 1-1 shows the sync mode.

| V.BLK |     |                 |     |       |  |  |  |
|-------|-----|-----------------|-----|-------|--|--|--|
| H.BLK | SOF | Effective Pixel |     | H.BLK |  |  |  |
| H.BLK |     | Effective Pixel |     | H.BLK |  |  |  |
| H.BLK |     | Effective Pixel |     | H.BLK |  |  |  |
| H.BLK |     | Effective Pixel |     | H.BLK |  |  |  |
| :     |     | !               |     | :     |  |  |  |
| H.BLK |     | Effective Pixel | EOL | H.BLK |  |  |  |
| H.BLK | SOL | Effective Pixel |     | H.BLK |  |  |  |
| H.BLK |     | Effective Pixel |     | H.BLK |  |  |  |
| H.BLK | _   | Effective Pixel |     | H.BLK |  |  |  |
| H.BLK |     | Effective Pixel |     | H.BLK |  |  |  |
| H.BLK |     | Effective Pixel |     | H.BLK |  |  |  |
| H.BLK |     | Effective Pixel | EOF | H.BLK |  |  |  |
| V.BLK |     |                 |     |       |  |  |  |

Figure 1-1 SOF/EOF/SOL/EOL sync mode

 SAV (invalid) and EAV (invalid) indicate the start and end of invalid data in the blanking region respectively, and SAV (valid) and EAV (valid) indicate the start and end of valid pixel data respectively.

Each sync code consists of four fields. The bit width of each field is consistent with that of pixel data. The first three fields are fixed reference codewords, and the fourth field is defined by the sensor vendor.

Because the sync code differs according to the sensor, it needs to be configured based on the sensor. Figure 1-2 shows the sync mode.



H.BLK V.BLK H.BLK SAV EAV (Invalid V.BLK H.BLK (Invalid H.BLK line) V.BLK line) H.BLK H.BLK H.OB / effective pixel H.BLK H.BLK H.OB / effective pixel H.BLK H.BLK H.OB / effective pixel H.BLK H.BLK SAV H.BLK EAV H.BLK H.OB / effective pixel (Valid (Valid H.BLK H.BLK H.OB / effective pixel line) line) H.BLK H.BLK H.OB / effective pixel H.BLK H.BLK V.BLK Ē SAV EAV H.BLK H.BLK (Invalid V.BLK (Invalid

Figure 1-2 SAV/EAV sync mode

DOL

H.BLK

H.BLK

Digital overlap (DOL) indicates the WDR function of Sony.

V.BLK

V.BLK

# 1.3 Function Description

The MIPI RX module is a collection unit that supports multiple differential video input interfaces. It uses the combo-PHY to receive data through the MIPI, LVDS, sub-LVDS, HiSPi, or DC interface. Depending on the functional mode configuration, the MIPI RX allows data transmission at different speeds and resolutions and supports multiple external input devices. Table 1-1 shows the maximum number of lanes supported by each chip.

H.BLK

H.BLK

line)

**Table 1-1** Maximum number of lanes

line)

| Chip                                      | Maximum Number of Lanes                 |
|-------------------------------------------|-----------------------------------------|
| Hi3559A V100ES                            | 8-lane MIPI input or 16-lane LVDS input |
| Hi3559A V100                              | 8-lane MIPI input or 16-lane LVDS input |
| Hi3519A V100                              | 8-lane MIPI input or 12-lane LVDS input |
| Hi3516C V500/Hi3516E<br>V300/Hi3516D V200 | 4-lane MIPI input or 4-lane LVDS input  |
| Hi3516E V200/Hi3518E V300                 | 2-lane MIPI input or 2-lane LVDS input  |

The MIPI RX can interwork with multiple sensors at a time. Table 1-2 describes the maximum sensors supported by each chip.



Table 1-2 Maximum number of sensors

| Chip           | Maximum Number of Sensors |
|----------------|---------------------------|
| Hi3559A V100ES | 6                         |
| Hi3559A V100   | 8                         |
| Hi3519A V100   | 5                         |
| Hi3516C V5000  | 1                         |
| Hi3516E V200   |                           |
| Hi3516E V300   |                           |
| Hi3518E V300   |                           |
| Hi3516D V300   | 2                         |
| Hi3559 V200    |                           |
| Hi3556 V200    |                           |
| Hi3516A V300   |                           |

Connecting to different number of sensors requires different number of lanes. Therefore, you need to determine the lane distribution mode of the MIPI RX. For details about the lane distribution mode, see Table 1-3.

Table 1-3 MIPI RX lane distribution mode

| Chip    | Mode | DEV0   | DEV1  | DEV2          | DEV3      | DEV4           | DEV5              | DEV6 | DEV7 |
|---------|------|--------|-------|---------------|-----------|----------------|-------------------|------|------|
| Hi3559A | 0    | L0-L15 | N     | N             | N         | N              | N                 | N    | N    |
| V100ES  | 1    | L0-L11 | N     | N             | N         | L12–L15        | N                 | N    | N    |
|         | 2    | L0-L11 | N     | N             | N         | L12 and<br>L14 | L13<br>and<br>L15 | N    | N    |
|         | 3    | L0-L7  | N     | L8-<br>L15    | N         | N              | N                 | N    | N    |
|         | 4    | L0-L7  | N     | L8-<br>L11    | N         | L12–L15        | N                 | N    | N    |
|         | 5    | L0-L7  | N     | L8-<br>L11    | N         | L12 and<br>L14 | L13<br>and<br>L15 | N    | N    |
|         | 6    | L0-L7  | N     | L8 and<br>L10 | L9<br>L11 | L12 and<br>L14 | L13<br>and<br>L15 | N    | N    |
|         | 7    | L0-L3  | L4-L7 | L8-<br>L11    | N         | L12–L15        | N                 | N    | N    |
|         | 8    | L0-L3  | L4-L7 | L8-<br>L11    | N         | L12 and<br>L14 | L13<br>and        | N    | N    |



| Chip         | Mode | DEV0         | DEV1         | DEV2          | DEV3          | DEV4           | DEV5              | DEV6           | DEV7              |
|--------------|------|--------------|--------------|---------------|---------------|----------------|-------------------|----------------|-------------------|
|              |      |              |              |               |               |                | L15               |                |                   |
|              | 9    | L0-L3        | L4–L7        | L8 and<br>L10 | L9<br>L11     | L12 and<br>L14 | L13<br>and<br>L15 | N              | N                 |
| Hi3559A V100 | 0    | L0-L15       | N            | N             | N             | N              | N                 | N              | N                 |
|              | 1    | L0-L11       | N            | N             | N             | N              | N                 | L12-L15        | N                 |
|              | 2    | L0-L11       | N            | N             | N             | N              | N                 | L12 and<br>L14 | L13<br>and<br>L15 |
|              | 3    | L0-L7        | N            | N             | N             | L8-L15         | N                 | N              | N                 |
|              | 4    | L0-L7        | N            | N             | N             | L8-L11         | N                 | L12-L15        | N                 |
|              | 5    | L0-L7        | N            | N             | N             | L8-L11         | N                 | L12 and<br>L14 | L13<br>and<br>L15 |
|              | 6    | L0-L7        | N            | N             | N             | L8 and<br>L10  | L9<br>L11         | L12 and<br>L14 | L13<br>and<br>L15 |
|              | 7    | L0-L3        | N            | L4-L7         | N             | L8-L11         | N                 | L12–L15        | N                 |
|              | 8    | L0-L3        | N            | L4-L7         | N             | L8-L11         | N                 | L12 and<br>L14 | L13<br>and<br>L15 |
|              | 9    | L0-L3        | N            | L4-L7         | N             | L8 and<br>L10  | L9 and<br>L11     | L12 and<br>L14 | L13<br>and<br>L15 |
|              | A    | L0-L3        | N            | L4 and<br>L6  | L5 and<br>L7  | L8 and<br>L10  | L9 and<br>L11     | L12 and<br>L14 | L13<br>and<br>L15 |
|              | В    | L0 and<br>L2 | L1 and<br>L3 | L4 and<br>L6  | L5 and<br>L7  | L8 and<br>L10  | L9 and<br>L11     | L12 and<br>L14 | L13<br>and<br>L15 |
| Hi3519A V100 | 0    | L0-L11       | N            | N             | N             | N              | N                 | N              | N                 |
|              | 1    | L0-L7        | N            | N             | L8-<br>L11    | N              | N                 | N              | N                 |
|              | 2    | L0-L7        | N            | N             | L8 and<br>L10 | L9 and<br>L11  | N                 | N              | N                 |
|              | 3    | L0-L3        | L4-<br>L11   | N             | N             | N              | N                 | N              | N                 |
|              | 4    | L0-L3        | L4-L7        | N             | L8-<br>L11    | N              | N                 | N              | N                 |
|              | 5    | L0-L3        | L4-L7        | N             | L8 and        | L9 and         | N                 | N              | N                 |



| Chip         | Mode | DEV0         | DEV1         | DEV2  | DEV3          | DEV4          | DEV5 | DEV6 | DEV7 |
|--------------|------|--------------|--------------|-------|---------------|---------------|------|------|------|
|              |      |              |              |       | L10           | L11           |      |      |      |
|              | 6    | L0-L3        | L4 and<br>L6 | L5 L7 | L8 and<br>L10 | L9 and<br>L11 | N    | N    | N    |
| Hi3516C V500 | 0    | L0-L3        | N            | N     | N             | N             | N    | N    | N    |
|              | 1    | L0 and<br>L2 | L1 and<br>L3 | N     | N             | N             | N    | N    | N    |
| Hi3516E V200 | 0    | L0 and<br>L2 | N            | N     | N             | N             | N    | N    | N    |
| Hi3516E V300 | 0    | L0-L3        | N            | N     | N             | N             | N    | N    | N    |

The SLVS-EC interface supports image capture with higher frame rate and resolution. By receiving high-speed serial data through PHY, converting data into the DC timing, and configuring different functional modes, the SLVS-EC can support multiple external input devices and the transmission of data with multiple speeds and resolutions. Table 1-4 shows the maximum number of supported lanes.

**Table 1-4** Maximum number of lanes

| Chip                          | Definition                                           |
|-------------------------------|------------------------------------------------------|
| Hi3559A V100ES                | The SLVS-EC supports a maximum of 8-lane SLVS input. |
| Hi3559A V100                  | The SLVS-EC supports a maximum of 8-lane SLVS input. |
| Hi3519A V100                  | The SLVS-EC supports a maximum of 8-lane SLVS input. |
| Hi3516C V500/<br>Hi3516E V200 | SLVS-EC input is not supported.                      |

The lane pins of MIPI RX are multiplexed with that of the SLVS-EC. A lane can be used by the MIPI RX or SLVS-EC at a time. For details about the lane pin connection, see Table 1-5.

Table 1-5 Lane multiplexing relationship between MIPI RX and SLVS-EC

| Chip    | LANE  | MIPI<br>0 | MIPI<br>1 | MIPI<br>2 | MIPI<br>3 | MIPI<br>4 | MIPI<br>5 | MIPI<br>6 | MIPI<br>7 | SL<br>VS<br>0 | SL<br>VS1    | SL<br>VS<br>2 | SL<br>VS3 |
|---------|-------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|---------------|--------------|---------------|-----------|
| Hi3559A | Lane0 | $\sqrt{}$ | -         | -         | -         | -         | -         | -         | -         | <b>V</b>      | $\checkmark$ | -             | -         |
| V100ES  | Lane1 | <b>√</b>  | -         | -         | -         | -         | -         | -         | -         | <b>V</b>      | <b>V</b>     | -             | -         |
|         | Lane2 | <b>√</b>  | -         | -         | -         | -         | -         | -         | -         | <b>V</b>      | <b>V</b>     | -             | -         |
|         | Lane3 | <b>√</b>  | -         | -         | -         | -         | -         | -         | -         | 1             | <b>V</b>     | -             | -         |
|         | Lane4 | <b>√</b>  | <b>√</b>  | -         | -         | -         | -         | -         | -         | <b>V</b>      | $\sqrt{}$    | -             | -         |



| Chip   | LANE   | MIPI<br>0    | MIPI<br>1 | MIPI<br>2 | MIPI<br>3 | MIPI<br>4    | MIPI<br>5    | MIPI<br>6 | MIPI<br>7 | SL<br>VS<br>0 | SL<br>VS1 | SL<br>VS<br>2 | SL<br>VS3    |
|--------|--------|--------------|-----------|-----------|-----------|--------------|--------------|-----------|-----------|---------------|-----------|---------------|--------------|
|        | Lane5  | $\sqrt{}$    | $\sqrt{}$ | 1         | -         | -            | -            | -         | -         | $\sqrt{}$     | V         | -             | -            |
|        | Lane6  | $\checkmark$ | $\sqrt{}$ | 1         | -         | -            | -            | -         | -         | <b>V</b>      | <b>V</b>  | -             | -            |
|        | Lane7  | $\sqrt{}$    | $\sqrt{}$ | -         | -         | -            | -            | -         | -         | $\sqrt{}$     | $\sqrt{}$ | -             | -            |
|        | Lane8  | $\sqrt{}$    | -         | $\sqrt{}$ |           |              | -            | -         | -         | -             | -         | $\sqrt{}$     | $\checkmark$ |
|        | Lane9  | $\checkmark$ | 1         | $\sqrt{}$ | $\sqrt{}$ |              | -            | -         | -         | -             | -         | $\sqrt{}$     | $\checkmark$ |
|        | Lane10 | $\sqrt{}$    | -         | $\sqrt{}$ |           |              | -            | -         | -         | -             | -         | $\sqrt{}$     | $\checkmark$ |
|        | Lane11 | $\sqrt{}$    | -         | $\sqrt{}$ | √         |              | -            | -         | -         | -             | -         | <b>√</b>      | $\checkmark$ |
|        | Lane12 | $\sqrt{}$    | -         | -         | -         | $\checkmark$ |              | -         | -         | -             | -         | $\sqrt{}$     | $\checkmark$ |
|        | Lane13 | $\sqrt{}$    | -         | -         | -         | √            | √            | -         | -         | -             | -         | <b>√</b>      | $\checkmark$ |
|        | Lane14 | $\sqrt{}$    | -         | -         | -         | √            |              | -         | -         | -             | -         | <b>√</b>      | $\checkmark$ |
|        | Lane15 | <b>√</b>     | -         | -         | -         | √            | √            | -         | -         | -             | -         | <b>V</b>      | $\checkmark$ |
| Hi3559 | Lane0  | $\sqrt{}$    |           |           |           |              |              |           |           | √             | 1         | -             | -            |
| A V100 | Lane1  | $\sqrt{}$    | $\sqrt{}$ |           |           |              |              |           |           | <b>V</b>      | 1         | -             | -            |
|        | Lane2  | $\sqrt{}$    |           |           |           |              |              |           |           | √             | 1         | -             | -            |
|        | Lane3  | $\sqrt{}$    | $\sqrt{}$ |           |           |              |              |           |           | √             | 1         | -             | -            |
|        | Lane4  | <b>√</b>     |           | <b>√</b>  |           |              |              |           |           | √             | 1         | -             | -            |
|        | Lane5  | $\sqrt{}$    |           | $\sqrt{}$ | √         |              |              |           |           | √             | 1         | -             | -            |
|        | Lane6  | $\sqrt{}$    |           | $\sqrt{}$ |           |              |              |           |           | √             | 1         | -             | -            |
|        | Lane7  | $\sqrt{}$    |           | $\sqrt{}$ | $\sqrt{}$ |              |              |           |           | $\sqrt{}$     | $\sqrt{}$ | -             | -            |
|        | Lane8  | $\sqrt{}$    |           |           |           | √            |              |           |           | -             | -         | <b>√</b>      | $\checkmark$ |
|        | Lane9  | $\sqrt{}$    |           |           |           | $\checkmark$ | $\sqrt{}$    |           |           | -             | -         | $\sqrt{}$     | $\checkmark$ |
|        | Lane10 | $\sqrt{}$    |           |           |           | $\checkmark$ |              |           |           | -             | -         | $\sqrt{}$     | $\checkmark$ |
|        | Lane11 | $\checkmark$ |           |           |           | $\checkmark$ | $\checkmark$ |           |           | -             | -         | $\sqrt{}$     | $\checkmark$ |
|        | Lane12 | $\checkmark$ |           |           |           | $\sqrt{}$    |              | √         |           | -             | -         | <b>V</b>      | $\checkmark$ |
|        | Lane13 | $\checkmark$ |           |           |           | $\sqrt{}$    |              | √         | $\sqrt{}$ | -             | -         | <b>V</b>      | $\checkmark$ |
|        | Lane14 | <b>√</b>     |           |           |           | <b>√</b>     |              | √         |           | -             | -         | <b>V</b>      | <b>√</b>     |
|        | Lane15 | $\sqrt{}$    |           |           |           | <b>√</b>     |              | <b>√</b>  | <b>√</b>  | -             | -         | <b>V</b>      | $\checkmark$ |
| Hi3519 | Lane0  | <b>√</b>     |           |           |           |              |              |           |           | <b>V</b>      |           |               |              |
| A V100 | Lane1  | $\sqrt{}$    |           |           |           |              |              |           |           | V             |           |               |              |
|        | Lane2  | <b>V</b>     |           |           |           |              |              |           |           | <b>V</b>      |           |               |              |



| Chip | LANE   | MIPI<br>0    | MIPI<br>1 | MIPI<br>2 | MIPI<br>3 | MIPI<br>4 | MIPI<br>5 | MIPI<br>6 | MIPI<br>7 | SL<br>VS<br>0 | SL<br>VS1 | SL<br>VS<br>2 | SL<br>VS3 |
|------|--------|--------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|---------------|-----------|---------------|-----------|
|      | Lane3  | $\checkmark$ |           |           |           |           |           |           |           | <b>V</b>      |           |               |           |
|      | Lane4  | $\sqrt{}$    | <b>√</b>  |           |           |           |           |           |           | <b>V</b>      |           |               |           |
|      | Lane5  | <b>√</b>     | √         | √         |           |           |           |           |           | <b>V</b>      |           |               |           |
|      | Lane6  | <b>√</b>     | <b>√</b>  |           |           |           |           |           |           | <b>V</b>      |           |               |           |
|      | Lane7  | <b>√</b>     | <b>√</b>  | √         |           |           |           |           |           | <b>V</b>      |           |               |           |
|      | Lane8  | √            | <b>√</b>  |           | <b>√</b>  |           |           |           |           |               |           |               |           |
|      | Lane9  | <b>√</b>     | <b>√</b>  |           | <b>√</b>  | √         |           |           |           |               |           |               |           |
|      | Lane10 | <b>√</b>     | <b>√</b>  |           | <b>√</b>  |           |           |           |           |               |           |               |           |
|      | Lane11 | $\sqrt{}$    | $\sqrt{}$ |           | $\sqrt{}$ | <b>√</b>  |           |           |           |               |           |               |           |

# 1.4 API Reference

The MIPI RX provides the function of interworking with sensor timings. It provides the ioctl interface and the following APIs:

- HI\_MIPI\_SET\_DEV\_ATTR: Sets the attributes of MIPI, SLVS, and parallel devices.
- HI\_MIPI\_SET\_HS\_MODE: Sets the lane distribution of the MIPI RX.
- HI\_MIPI\_SET\_PHY\_CMVMODE: Configures the common-mode voltage mode.
- HI\_MIPI\_RESET\_SENSOR: Resets the sensor.
- HI\_MIPI\_UNRESET\_SENSOR: Deasserts the reset on the sensor.
- HI\_MIPI\_RESET\_MIPI: Resets the MIPI RX.
- HI\_MIPI\_UNRESET\_MIPI: Deasserts the reset on the MIPI RX.
- HI\_MIPI\_RESET\_SLVS: Resets the SLVS.
- HI MIPI UNRESET SLVS: Deasserts the reset on the SLVS.
- HI\_MIPI\_ENABLE\_MIPI\_CLOCK: Enables the clock of the MIPI device.
- HI MIPI DISABLE MIPI CLOCK: Disables the clock of the MIPI device.
- HI\_MIPI\_ENABLE\_SLVS\_CLOCK: Enables the clock of the SLVS device.
- HI\_MIPI\_DISABLE\_SLVS\_CLOCK: Disables the clock of the SLVS device.
- HI MIPI ENABLE SENSOR CLOCK: Enables the sensor clock.
- HI\_MIPI\_DISABLE\_SENSOR\_CLOCK: Disables the sensor clock.
- HI\_MIPI\_CLEAR: Clears the configurations of the device.

The MIPI TX provides the display and cascading functions. It provides the ioctl interface and the following APIs:

- HI\_MIPI\_TX\_SET\_DEV\_CFG: Sets the attributes of an MIPI RX device.
- HI MIPI TX SET CMD: Sets the command data to be sent to an MIPI TX device.



- HI\_MIPI\_TX\_ENABLE: Enables the MIPI TX device.
- HI\_MIPI\_TX\_DISABLE: Disables the MIPI TX device.
- HI\_MIPI\_TX\_GET\_CMD: Reads information from peripherals.

# **NOTICE**

If the VO does not use MIPI\_TX for output, it is forbidden to use the MIPI\_TX interface and use MIPI\_TX output for the boot screen. After the interface is called, the MIPI\_TX will be enabled. When the supply voltage of AVDD3318\_MIPITX exceeds 1.8 V, MIPI\_TX will be damaged.

#### HI\_MIPI\_SET\_DEV\_ATTR

[Description]

Sets the attributes of MIPI and SLVS devices.

[Definition]

[Parameter]

combo\_dev\_attr\_t pointer

[Return Value]

| Return Value | Description                   |
|--------------|-------------------------------|
| 0            | Success                       |
| -1           | Failure. errno is configured. |

[Chip Difference]

None

[Requirement]

Header file: hi\_mipi.h

#### [Note]

- The following APIs also need to be configured besides HI\_MIPI\_SET\_DEV\_ATTR.
- Setting the mode: The API is HI\_MIPI\_SET\_HS\_MODE.
- Enabling the MIPI/SLVS clock: The API is HI\_MIPI\_ENABLE\_MIPI\_CLOCK/HI\_MIPI\_ENABLE\_SLVS\_CLOCK.
- Resetting the MIPI/SLVS: The API is HI\_MIPI\_RESET\_MIPI/HI\_MIPI\_RESET\_SLVS.
- Enabling the sensor clock: The API is HI\_MIPI\_ENABLE\_SENSOR\_CLOCK.
- Resetting the sensor: The API is HI\_MIPI\_RESET\_SENSOR.



- Deasserting the reset on the MIPI/SLVS: The API is HI\_MIPI\_UNRESET\_MIPI/HI\_MIPI\_UNRESET\_SLVS.
- Deasserting the reset on the sensor: The API is HI\_MIPI\_UNRESET\_SENSOR.
- The recommended configuration process is as follows:
  - 1. Set the mode.
  - 2. Enable the clocks of multiple MIPI/SLVS.
  - 3. Reset the MIPI RX/SLVS connected to multiple sensors.
  - 4. Enable the clocks connected to multiple sensors.
  - 5. Reset all connected sensors.
  - 6. Set the attributes of the MIPI RX/SLVS.
  - 7. Deassert the reset on the MIPI RX/SLVS connected to multiple sensors.
  - 8. Deassert the reset on all connected sensors.
- The recommended exiting process is as follows:
  - 1. Reset all connected sensors.
  - 2. Disable the clocks connected to multiple sensors.
  - 3. Reset the MIPI RX/SLVS connected to multiple sensors.
  - 4. Clear the configurations of the MIPI RX/SLVS devices connected to multiple sensors.
  - 5. Disable the clocks of multiple MIPI/SLVS devices.
- Operating sensor reset signal cables or clock signal cables affects all sensors connected to the cables.

#### [See Also]

- HI\_MIPI\_SET\_HS\_MODE
- HI\_MIPI\_RESET\_SLVS
- HI\_MIPI\_UNRESET\_SLVS
- HI MIPI RESET SENSOR
- HI\_MIPI\_UNRESET\_SENSOR
- HI\_MIPI\_RESET\_MIPI
- HI\_MIPI\_UNRESET\_MIPI

#### HI\_MIPI\_SET\_HS\_MODE

#### [Description]

Sets the lane distribution of the MIPI RX (invalid for the SLVS).

#### [Definition]

```
#define HI_MIPI_SET_HS_MODE __IOW(HI_MIPI_IOC_MAGIC, 0x0b,
lane_divide_mode_t)
```

#### [Parameter]

lane\_divide\_mode\_t pointer

[Return Value]



| Return Value | Description                   |
|--------------|-------------------------------|
| 0            | Success                       |
| -1           | Failure. errno is configured. |

#### [Chip Difference]

| Chip           | Supported or Not |
|----------------|------------------|
| Hi3559A V100ES | Supported        |
| Hi3559A V100   | Supported        |
| Hi3519A V100   | Supported        |
| Hi3516C V500   | Supported        |
| Hi3516E V200   | Supported        |

#### [Requirement]

Header file: hi\_mipi.h

[Note]

When multiple sensor inputs are connected, you are advised to arrange the global lane distribution based on the hardware connection during initialization. This API cannot be called during multi-sensor data collection. Otherwise, the data collection of other sensors may be affected.

#### HI\_MIPI\_SET\_PHY\_CMVMODE

[Description]

Configures the common-mode voltage mode.

#### [Definition]

```
#define HI_MIPI_SET_PHY_CMVMODE __IOW(HI_MIPI_IOC_MAGIC, 0x04,
phy_cmv_t)
```

#### [Parameter]

phy\_cmv\_t, indicating the pointer

#### [Return Value]

| Return Value | Description                   |
|--------------|-------------------------------|
| 0            | Success                       |
| -1           | Failure. errno is configured. |

#### [Chip Difference]

| Chip           | Supported or Not |
|----------------|------------------|
| Hi3559A V100ES | Supported        |
| Hi3559A V100   | Supported        |
| Hi3519A V100   | Supported        |
| Hi3516C V500   | Supported        |
| Hi3516E V200   | Supported        |

[Requirement]

Header file: hi\_mipi.h

[Note]

The SLVS mode is not supported.

#### HI\_MIPI\_RESET\_SENSOR

[Description]

Resets the sensor.

[Definition]

```
#define HI_MIPI_RESET_SENSOR __IOW(HI_MIPI_IOC_MAGIC, 0x05,
sns_rst_source_t)
```

#### [Parameter]

sns\_rst\_source\_t, indicating the sensor reset signal cable number

#### [Return Value]

| Return Value | Description                   |
|--------------|-------------------------------|
| 0            | Success                       |
| -1           | Failure. errno is configured. |

#### [Chip Difference]

| Chip           | Supported or Not |
|----------------|------------------|
| Hi3559A V100ES | Supported        |
| Hi3559A V100   | Supported        |
| Hi3519A V100   | Supported        |
| Hi3516C V500   | Supported        |



| Chip         | Supported or Not |
|--------------|------------------|
| Hi3516E V200 | Supported        |

[Requirement]

Header file: hi\_mipi.h

[Note]

None

# HI\_MIPI\_UNRESET\_SENSOR

[Description]

Deasserts the reset on the sensor.

[Definition]

[Parameter]

sns\_rst\_source\_t, indicating the sensor reset signal cable number

[Return Value]

| Return Value | Description                   |
|--------------|-------------------------------|
| 0            | Success                       |
| -1           | Failure. errno is configured. |

#### [Chip Difference]

| Chip           | Supported or Not |
|----------------|------------------|
| Hi3559A V100ES | Supported        |
| Hi3559A V100   | Supported        |
| Hi3519A V100   | Supported        |
| Hi3516C V500   | Supported        |
| Hi3516E V200   | Supported        |

[Requirement]

Header file: hi\_mipi.h

[Note]



None

# HI\_MIPI\_RESET\_MIPI

[Description]

Resets the MIPI RX.

[Definition]

```
#define HI_MIPI_RESET_MIPI __IOW(HI_MIPI_IOC_MAGIC, 0x07, combo_dev_t)
```

[Parameter]

combo\_dev\_t, indicating the device ID

[Return Value]

| Return Value | Description                   |
|--------------|-------------------------------|
| 0            | Success                       |
| -1           | Failure. errno is configured. |

#### [Chip Difference]

| Chip           | Supported or Not |
|----------------|------------------|
| Hi3559A V100ES | Supported        |
| Hi3559A V100   | Supported        |
| Hi3519A V100   | Supported        |
| Hi3516C V500   | Supported        |
| Hi3516E V200   | Supported        |

[Requirement]

Header file: hi\_mipi.h

[Note]

None

#### HI\_MIPI\_UNRESET\_MIPI

[Description]

Deasserts the reset on the MIPI RX.

[Definition]

```
#define HI_MIPI_UNRESET_MIPI _IOW(HI_MIPI_IOC_MAGIC, 0x08, combo_dev_t)
```

[Parameter]



combo\_dev\_t, indicating the device ID

#### [Return Value]

| Return Value | Description                   |
|--------------|-------------------------------|
| 0            | Success                       |
| -1           | Failure. errno is configured. |

#### [Chip Difference]

| Chip           | Supported or Not |
|----------------|------------------|
| Hi3559A V100ES | Supported        |
| Hi3559A V100   | Supported        |
| Hi3519A V100   | Supported        |
| Hi3516C V500   | Supported        |
| Hi3516E V200   | Supported        |

[Requirement]

Header file: hi\_mipi.h

[Note]

None

#### **HI\_MIPI\_RESET\_SLVS**

[Description]

Resets the SLVS.

[Definition]

```
#define HI_MIPI_RESET_SLVS __IOW(HI_MIPI_IOC_MAGIC, 0x09,
combo_dev_t)
```

#### [Parameter]

combo\_dev\_t, indicating the device ID

[Return Value]

| Return Value | Description                   |
|--------------|-------------------------------|
| 0            | Success                       |
| -1           | Failure. errno is configured. |

#### [Chip Difference]

| Chip           | Supported or Not |
|----------------|------------------|
| Hi3559A V100ES | Supported        |
| Hi3559A V100   | Supported        |
| Hi3519A V100   | Supported        |
| Hi3516C V500   | Not supported    |
| Hi3516E V200   | Not supported    |

[Requirement]

Header file: hi\_mipi.h

[Note]

None

#### **HI\_MIPI\_UNRESET\_SLVS**

[Description]

Deasserts the reset on the SLVS.

[Definition]

#### [Parameter]

combo\_dev\_t, indicating the device ID

[Return Value]

| Return Value | Description                   |
|--------------|-------------------------------|
| 0            | Success                       |
| -1           | Failure. errno is configured. |

#### [Chip Difference]

| Chip           | Supported or Not |
|----------------|------------------|
| Hi3559A V100ES | Supported        |
| Hi3559A V100   | Supported        |
| Hi3519A V100   | Supported        |
| Hi3516C V500   | Not supported    |



| Chip         | Supported or Not |
|--------------|------------------|
| Hi3516E V200 | Not supported    |

[Requirement]

Header file: hi\_mipi.h

[Note]

None

#### HI\_MIPI\_ENABLE\_MIPI\_CLOCK

[Description]

Enables the clock of the MIPI device.

[Definition]

```
#define HI_MIPI_ENABLE_MIPI_CLOCK __IOW(HI_MIPI_IOC_MAGIC,
0x0c, combo_dev_t)
```

[Parameter]

combo\_dev\_t, indicating the device ID

[Return Value]

| Return Value | Description                   |
|--------------|-------------------------------|
| 0            | Success                       |
| -1           | Failure. errno is configured. |

#### [Chip Difference]

| Chip           | Supported or Not |
|----------------|------------------|
| Hi3559A V100ES | Supported        |
| Hi3559A V100   | Supported        |
| Hi3519A V100   | Supported        |
| Hi3516C V500   | Supported        |
| Hi3516E V200   | Supported        |

[Requirement]

Header file: hi\_mipi.h

[Note]



None

# HI\_MIPI\_DISABLE\_MIPI\_CLOCK

[Description]

Disables the clock of the MIPI device.

[Definition]

```
#define HI_MIPI_DISABLE_MIPI_CLOCK __IOW(HI_MIPI_IOC_MAGIC,
0x0d, combo_dev_t)
```

#### [Parameter]

combo\_dev\_t, indicating the device ID

#### [Return Value]

| Return Value | Description                   |
|--------------|-------------------------------|
| 0            | Success                       |
| -1           | Failure. errno is configured. |

#### [Chip Difference]

| Chip           | Supported or Not |
|----------------|------------------|
| Hi3559A V100ES | Supported        |
| Hi3559A V100   | Supported        |
| Hi3519A V100   | Supported        |
| Hi3516C V500   | Supported        |
| Hi3516E V200   | Supported        |

[Requirement]

Header file: hi\_mipi.h

[Note]

None

#### HI\_MIPI\_ENABLE\_SLVS\_CLOCK

[Description]

Enables the clock of the SLVS device.

[Definition]

#define HI\_MIPI\_ENABLE\_SLVS\_CLOCK \_\_IOW(HI\_MIPI\_IOC\_MAGIC,

0x0e, combo\_dev\_t)

[Parameter]

combo\_dev\_t, indicating the device ID

[Return Value]

| Return Value | Description                   |
|--------------|-------------------------------|
| 0            | Success                       |
| -1           | Failure. errno is configured. |

#### [Chip Difference]

| Chip           | Supported or Not |
|----------------|------------------|
| Hi3559A V100ES | Supported        |
| Hi3559A V100   | Supported        |
| Hi3519A V100   | Supported        |
| Hi3516C V500   | Not supported    |
| Hi3516E V200   | Not supported    |

[Requirement]

Header file: hi\_mipi.h

[Note]

None

#### HI\_MIPI\_DISABLE\_SLVS\_CLOCK

[Description]

Disables the clock of the SLVS device.

[Definition]

```
#define HI_MIPI_DISABLE_SLVS_CLOCK __IOW(HI_MIPI_IOC_MAGIC,
0x0f, combo_dev_t)
```

[Parameter]

combo\_dev\_t, indicating the device ID

[Return Value]

| Return Value | Description |
|--------------|-------------|
| 0            | Success     |



| Return Value | Description                   |
|--------------|-------------------------------|
| -1           | Failure. errno is configured. |

#### [Chip Difference]

| Chip           | Supported or Not |
|----------------|------------------|
| Hi3559A V100ES | Supported        |
| Hi3559A V100   | Supported        |
| Hi3519A V100   | Supported        |
| Hi3516C V500   | Not supported    |
| Hi3516E V200   | Not supported    |

[Requirement]

Header file: hi\_mipi.h

[Note]

None

# HI\_MIPI\_ENABLE\_SENSOR\_CLOCK

[Description]

Enables the sensor clock.

[Definition]

```
#define HI_MIPI_ENABLE_SENSOR_CLOCK __IOW(HI_MIPI_IOC_MAGIC, 0x10,
sns_clk_source_t)
```

[Parameter]

Source ID of the sensor clock device

[Return Value]

| Return Value | Description                   |
|--------------|-------------------------------|
| 0            | Success                       |
| -1           | Failure. errno is configured. |

#### [Chip Difference]

| Chip           | Supported or Not |
|----------------|------------------|
| Hi3559A V100ES | Supported        |

| Hi3559A V100 | Supported |
|--------------|-----------|
| Hi3519A V100 | Supported |
| Hi3516C V500 | Supported |
| Hi3516E V200 | Supported |

[Requirement]

Header file: hi\_mipi.h

[Note]

None

# HI\_MIPI\_DISABLE\_SENSOR\_CLOCK

[Description]

Disables the sensor clock.

[Definition]

```
#define HI_MIPI_DISABLE_SENSOR_CLOCK __IOW(HI_MIPI_IOC_MAGIC, 0x11,
sns_clk_source_t)
```

[Parameter]

Source ID of the sensor clock device

[Return Value]

| Return Value | Description                   |
|--------------|-------------------------------|
| 0            | Success                       |
| -1           | Failure. errno is configured. |

#### [Chip Difference]

| Chip           | Supported or Not |
|----------------|------------------|
| Hi3559A V100ES | Supported        |
| Hi3559A V100   | Supported        |
| Hi3519A V100   | Supported        |
| Hi3516C V500   | Supported        |

[Requirement]

Header file: hi\_mipi.h



[Note]

None

# HI\_MIPI\_CLEAR

[Description]

Clears the configurations of the device.

[Syntax]

#define HI\_MIPI\_CLEAR \_\_IOW(HI\_MIPI\_IOC\_MAGIC, 0x12,
combo\_dev\_t)

[Parameter]

Device ID

[Return Value]

| Return Value | Description                   |
|--------------|-------------------------------|
| 0            | Success                       |
| -1           | Failure. errno is configured. |

#### [Chip Difference]

| Chip           | Supported or Not |
|----------------|------------------|
| Hi3559A V100ES | Not supported    |
| Hi3559A V100   | Supported        |
| Hi3519A V100   | Not supported    |
| Hi3516C V500   | Not supported    |
| Hi3516E V200   | Not supported    |

[Requirement]

Header file: hi\_mipi.h

[Note]

This MIPI is called when a service exits and is used to clear the configurations of the device.

#### HI\_MIPI\_TX\_SET\_DEV\_CFG

[Description]

Sets the attributes of an MIPI RX device.

[Definition]



[Parameter]

Attributes of an MIPI device

[[Return Value]

| Return Value | Description                   |
|--------------|-------------------------------|
| 0            | Success                       |
| -1           | Failure. errno is configured. |

#### [Chip Difference]

| Chip           | Supported or Not |
|----------------|------------------|
| Hi3559A V100ES | Not supported    |
| Hi3559A V100   | Supported        |
| Hi3519A V100   | Supported        |
| Hi3516C V500   | Supported        |
| Hi3516E V200   | Not supported    |

[Requirement]

Header file: hi\_mipi\_tx.h

[Note]

None

#### HI\_MIPI\_TX\_SET\_CMD

[Description]

Sets the command data to be sent to an MIPI TX device.

[Definition]

[Parameter]

Command data sent to an MIPI TX device

[[Return Value]

| Return Value | Description                   |
|--------------|-------------------------------|
| 0            | Success                       |
| -1           | Failure. errno is configured. |

#### [Chip Difference]

| Chip          | Supported or Not |
|---------------|------------------|
| Hi3559AV100ES | Not supported    |
| Hi3559AV100   | Supported        |
| Hi3519AV100   | Supported        |
| Hi3516C V500  | Supported        |
| Hi3516E V200  | Not supported    |

[Requirement]

Header file: hi\_mipi\_tx.h

[Note]

None

# HI\_MIPI\_TX\_GET\_CMD

[Description]

Reads information from peripherals.

[Syntax]

[Parameter]

For details, see get\_cmd\_info\_t.

[Return Value]

| Return Value | Description                   |
|--------------|-------------------------------|
| 0            | Success                       |
| -1           | Failure. errno is configured. |

[Difference]



| Chip Type      | Supported or Not |
|----------------|------------------|
| Hi3559A V100ES | Not supported    |
| Hi3559A V100   | Supported        |
| Hi3519A V100   | Supported        |
| Hi3516C V500   | Supported        |
| Hi3516E V200   | Not supported    |

[Requirement]

Header file: hi\_mipi\_tx.h

[Note]

None

#### HI\_MIPI\_TX\_ENABLE

[Description]

Enables an MIPI TX device.

[Definition]

#define HI\_MIPI\_TX\_ENABLE \_\_IO(HI\_MIPI\_TX\_IOC\_MAGIC, 0x03)

[Parameter]

None

[[Return Value]

| Return Value | Description                   |
|--------------|-------------------------------|
| 0            | Success                       |
| -1           | Failure. errno is configured. |

#### [Chip Difference]

| Chip          | Supported or Not |
|---------------|------------------|
| Hi3559AV100ES | Not supported    |
| Hi3559AV100   | Supported        |
| Hi3519AV100   | Supported        |
| Hi3516C V500  | Supported        |
| Hi3516E V200  | Not supported    |



[Requirement]

Header file: hi\_mipi\_tx.h

[Note]

After this API is called, the MIPI works in HS mode.

#### HI\_MIPI\_TX\_DISABLE

[Description]

Disables an MIPI TX device.

[Definition]

#define HI\_MIPI\_TX\_DISABLE \_\_IO(HI\_MIPI\_TX\_IOC\_MAGIC, 0x05)

[Parameter]

None

[[Return Value]

| Return Value | Description                   |
|--------------|-------------------------------|
| 0            | Success                       |
| -1           | Failure. errno is configured. |

#### [Chip Difference]

| Chip           | Supported or Not |
|----------------|------------------|
| Hi3559A V100ES | Not supported    |
| Hi3559A V100   | Supported        |
| Hi3519A V100   | Supported        |
| Hi3516C V500   | Supported        |
| Hi3516E V200   | Not supported    |

[Requirement]

Header file: hi\_mipi\_tx.h

[Note]

After this API is called, the MIPI works in LP mode.

# 1.5 Data Structures

The MIPI RX provides the following data structures:



• HI\_MIPI\_IOC\_MAGIC: Defines the magic number of the MIPI RX ioctl command.

- combo\_dev\_t: Defines the type of MIPI RX and SLVS devices.
- SNS\_MAX\_RST\_SOURCE\_NUM: Defines the number of reset signal cables of the sensor.
- SNS\_MAX\_CLK\_SOURCE\_NUM: Defines the number of clock signal cables of the sensor.
- sns\_rst\_source\_t: Defines the ID of a sensor reset signal cable. The cable is called the sensor reset source in terms of software.
- sns\_clk\_source\_t: Defines the ID of a sensor clock signal cable. The cable is called the sensor clock source in terms of software.
- MIPI\_RX\_MAX\_DEV\_NUM: Defines the number of devices supported by the MIPI RX.
- SLVS\_MAX\_DEV\_NUM: Defines the number of devices supported by the SLVS.
- SLVS DEV NUM START: Defines the start device ID of the SLVS.
- COMBO\_MAX\_LANE\_NUM: Specifies the maximum number of lanes supported by the device.
- MAX\_LANE\_NUM\_PER\_LINK: Specifies the number of lanes of an MIPI RX link.
- MIPI\_LANE\_NUM: Specifies the maximum number of lanes supported by the MIPI device of the MIPI RX.
- LVDS\_LANE\_NUM: Specifies the number of lanes supported by the LVDS/HiSPi interface.
- SLVS\_LANE\_NUM: Specifies the maximum number of lanes supported by the SLVS devices.
- COMS\_MAX\_DEV\_NUM: Specifies the maximum number of supported parallel devices.
- COMBO\_MAX\_LINK\_NUM: Specifies the maximum number of links supported by the MIPI RX.
- COMBO\_MAX\_DEV\_NUM: Specifies the number of the MIPI RX devices.
- WDR\_VC\_NUM: Specifies the maximum number of supported virtual channels.
- SYNC\_CODE\_NUM: Defines the number of sync codes of per virtual channel of the LVDS.
- lane\_divide\_mode\_t: Specifies the lane distribution of the MIPI RX.
- input\_mode\_t: Specifies the MIPI RX input modes.
- mipi\_data\_rate\_t: Defines the input rate of the MIPI RX and SLVS.
- img\_rect\_t: Defines crop attributes.
- slvs lane rate t: Defines the input rate of the SLVS lane.
- slvs err check mode t: Defines the SLVS error check mode.
- data\_type\_t: Defines the data type for transmission.
- mipi\_wdr\_mode\_t: Defines the MIPI WDR mode.
- mipi\_dev\_attr\_t: Defines the attributes of the MIPI device.
- wdr\_mode\_t: Defines the LVDS WDR mode.
- lvds\_sync\_mode\_t: Defines the LVDS sync mode.
- lvds bit endian t: Defines the bit endian mode.
- lvds\_vsync\_type\_t: Defines the LVDS vsync type.
- lvds vsync attr t: Defines the LVDS vsync parameter.



- lvds\_fid\_type\_t: Defines the frame ID type.
- lvds\_fid\_attr\_t: Defines the frame ID configuration information.
- mipi\_clk\_mode\_t: Defines the clock sharing mode.
- lvds\_lane\_work\_mode\_t: Defines the arrival mode of the synchronization code of the LVDS lane.
- lvds\_lane\_work\_attr\_t: Defines the working attributes of the synchronization code of the LVDS lane.
- lvds\_dev\_attr\_t: Defines the device attributes supported by the LVDS, SubLVDS, and HiSPi interfaces.
- <a href="lvds\_dev\_attr\_ex\_t">lvds\_dev\_attr\_ex\_t</a>: Defines the advanced device attributes supported by the LVDS, sub-LVDS, and HiSPi interfaces.
- slvs dev attr t: Defines the attributes of the SLVS device.
- phy\_cmv\_mode\_t: Defines the PHY common-mode voltage mode.
- phy\_cmv\_t: Defines the configuration information of the PHY common-mode voltage.
- combo\_dev\_attr\_t: Defines the combo device attributes.
- HI\_MIPI\_TX\_IOC\_MAGIC: Defines the magic number of MIPI RX ioctl in a command.
- LANE\_MAX\_NUM: Defines the maximum number of lanes supported by the MIPI TX.
- output\_mode\_t: Defines the MIPI TX output mode.
- video\_mode\_t: Defines the MIPI TX video mode.
- output\_format\_t: Defines the MIPI TX output format.
- sync\_info\_t: Defines the synchronization information of an MIPI TX device.
- combo\_dev\_cfg\_t: Defines the attributes of an MIPI TX device.
- cmd\_info\_t: Defines the command data to be sent to an MIPI TX device.
- get\_cmd\_info\_t: Defines the command information sent to the MIPI TX device.

## HI\_MIPI\_IOC\_MAGIC

[Description]

Defines the magic number of the MIPI RX ioctl in a command.

[Definition]

#define HI MIPI IOC MAGIC 'm'

[Member]

None

[Chip Difference]

None

[Note]

None

[See Also]

None



# combo\_dev\_t

[Description]

Defines the type of MIPI RX and SLVS devices.

[Definition]

typedef unsigned int combo\_dev\_t;

#### [Chip Difference]

| Chip           | MIPI Device Range           | SLVS Device Range                           |
|----------------|-----------------------------|---------------------------------------------|
| Hi3559A V100ES | [0,<br>MIPI_RX_MAX_DEV_NUM) | [SLVS_DEV_NUM_START,<br>COMBO_MAX_LANE_NUM) |
| Hi3559A V100   | [0,<br>MIPI_RX_MAX_DEV_NUM) | [SLVS_DEV_NUM_START,<br>SLVS_MAX_DEV_NUM)   |
| Hi3519A V100   | [0,<br>MIPI_RX_MAX_DEV_NUM) | [0, SLVS_MAX_DEV_NUM)                       |
| Hi3516C V500   | [0,<br>MIPI_RX_MAX_DEV_NUM) | 0                                           |

[Note]

None

## [See Also]

- combo\_dev\_attr\_t
- HI\_MIPI\_SET\_DEV\_ATTR
- HI\_MIPI\_RESET\_SENSOR
- HI\_MIPI\_UNRESET\_SENSOR
- HI\_MIPI\_RESET\_MIPI
- HI\_MIPI\_UNRESET\_MIPI

# SNS\_MAX\_RST\_SOURCE\_NUM

[Description]

Defines the number of reset signal cables of the sensor.

[Definition]

Hi3559A V100ES:

#define SNS\_MAX\_RST\_SOURCE\_NUM 3

Hi3559A V100:

#define SNS\_MAX\_RST\_SOURCE\_NUM 4

Hi3519AV100:

| #define SNS_MAX_RST_SOURCE_NUM | 3 |
|--------------------------------|---|
| Hi3516C V500:                  |   |
| #define SNS_MAX_RST_SOURCE_NUM | 2 |
| Hi3516E V200:                  |   |
| #define SNS_MAX_RST_SOURCE_NUM | 1 |

## [Chip Difference]

| Chip           | Number of Reset Signal Cables of the Sensor |
|----------------|---------------------------------------------|
| Hi3559A V100ES | 3                                           |
| Hi3559A V100   | 4                                           |
| Hi3519A V100   | 3                                           |
| Hi3516C V500   | 2                                           |
| Hi3516E V200   | 1                                           |

[Note]

None

[See Also]

None

# SNS\_MAX\_CLK\_SOURCE\_NUM

[Description]

Defines the number of clock signal cables of the sensor.

[Definition]

Hi3559A V100ES:

#define SNS\_MAX\_CLK\_SOURCE\_NUM 3

Hi3559A V100:

#define SNS\_MAX\_CLK\_SOURCE\_NUM 4

Hi3519AV100:

#define SNS\_MAX\_CLK\_SOURCE\_NUM 3

Hi3516C V500:

#define SNS\_MAX\_CLK\_SOURCE\_NUM 2

Hi3516E V200:

#define SNS\_MAX\_CLK\_SOURCE\_NUM 1



## [Chip Difference]

| Chip           | Number of Sensor Clock Signal Cables |
|----------------|--------------------------------------|
| Hi3559A V100ES | 3                                    |
| Hi3559A V100   | 4                                    |
| Hi3519A V100   | 3                                    |
| Hi3516C V500   | 2                                    |
| Hi3516E V200   | 1                                    |

[Note]

None

[See Also]

None

## sns\_rst\_source\_t

## [Description]

Defines the ID of a sensor reset signal cable. The cable is called the sensor reset source in terms of software.

## [Definition]

typedef unsigned int sns\_rst\_source\_t;

## [Chip Difference]

| Chip           | Sensor Reset Device Range   |
|----------------|-----------------------------|
| Hi3559A V100ES | [0, SNS_MAX_RST_SOURCE_NUM) |
| Hi3559A V100   | [0, SNS_MAX_RST_SOURCE_NUM) |
| Hi3519A V100   | [0, SNS_MAX_RST_SOURCE_NUM) |
| Hi3516C V500   | [0, SNS_MAX_RST_SOURCE_NUM) |
| Hi3516E V200   | [0, SNS_MAX_RST_SOURCE_NUM) |

## [Note]

Each sensor reset signal cable can connect to two sensors. You need to confirm the number of each sensor reset signal cable according to the signal cable connections on board.

## [See Also]

- HI\_MIPI\_RESET\_SLVS
- HI\_MIPI\_UNRESET\_SLVS



# sns\_clk\_source\_t

## [Description]

Defines the ID of a sensor clock signal cable. The cable is called the sensor clock source in terms of software.

#### [Definition]

typedef unsigned int sns\_clk\_source\_t;

## [Chip Difference]

| Chip           | Sensor Reset Device Range   |
|----------------|-----------------------------|
| Hi3559A V100ES | [0, SNS_MAX_CLK_SOURCE_NUM) |
| Hi3559A V100   | [0, SNS_MAX_CLK_SOURCE_NUM) |
| Hi3519A V100   | [0, SNS_MAX_CLK_SOURCE_NUM) |
| Hi3516C V500   | [0, SNS_MAX_CLK_SOURCE_NUM) |
| Hi3516E V200   | [0, SNS_MAX_CLK_SOURCE_NUM) |

## [Note]

Each sensor reset signal cable can connect to two sensors. You need to confirm the number of each sensor reset signal cable according to the signal cable connections on board.

#### [See Also]

- HI\_MIPI\_ENABLE\_SENSOR\_CLOCK
- HI\_MIPI\_DISABLE\_SENSOR\_CLOCK

# MIPI\_RX\_MAX\_DEV\_NUM

## [Description]

Defines the number of devices supported by the MIPI RX.

## [Definition]

## Hi3559A V100ES:

| #define MIPI_RX_MAX_DEV_NUM | 6 |
|-----------------------------|---|
| Hi3559A V100:               |   |
| #define MIPI_RX_MAX_DEV_NUM | 8 |
| Hi3519A V100:               |   |
| #define MIPI_RX_MAX_DEV_NUM | 5 |
| Hi3516C V500:               |   |
| #define MIPI RX MAX DEV NUM | 2 |



#### Hi3516E V200:

#define MIPI\_RX\_MAX\_DEV\_NUM 1

## [Chip Difference]

| Chip           | Number of Devices Supported by the MIPI RX |
|----------------|--------------------------------------------|
| Hi3559A V100ES | 6                                          |
| Hi3559A V100   | 8                                          |
| Hi3519A V100   | 5                                          |
| Hi3516C V500   | 2                                          |
| Hi3516E V200   | 1                                          |

## [Note]

- For Hi3516C V500, only one MIPI RX device is available at a time.
- For Hi3516D V300/Hi3559 V200/Hi3556 V200/Hi3516A V300, two MIPI RX devices are available at a time.

[See Also]

None

# SLVS\_MAX\_DEV\_NUM

[Description]

Defines the number of devices supported by the SLVS.

[Definition]

Hi3559A V100ES/Hi3559A V100:

#define SLVS\_MAX\_DEV\_NUM

Hi3519A V100:

#define SLVS\_MAX\_DEV\_NUM 1

[Chip Difference]

None

[Note]

None

[See Also]

None



# SLVS\_DEV\_NUM\_START

[Description]

Defines the start device ID of the SLVS.

[Definition]

Hi3559A V100ES:

#define SLVS\_DEV\_NUM\_START MIPI\_RX\_MAX\_DEV\_NUM

Hi3559A V100:

#define SLVS\_DEV\_NUM\_START 0

## [Chip Difference]

| Chip           | Start Device ID of the SLVS |
|----------------|-----------------------------|
| Hi3559A V100ES | MIPI_RX_MAX_DEV_NUM         |
| Hi3559A V100   | 0                           |

[Note]

None

[See Also]

None

# COMBO\_MAX\_LANE\_NUM

[Description]

Defines the total number of MIPI RX and SLVS lanes.

[Definition]

Hi3559A V100ES/Hi3559A V100:

#define COMBO\_MAX\_LANE\_NUM 16

Hi3519A V100:

#define COMBO\_MAX\_LANE\_NUM 12

Hi3516C V500:

#define COMBO\_MAX\_LANE\_NUM 4

Hi3516E V200:

#define COMBO\_MAX\_LANE\_NUM 2

Hi3516E V300:

#define COMBO\_MAX\_LANE\_NUM 4



[Chip Difference]

None

[Note]

None

[See Also]

None

# MAX\_LANE\_NUM\_PER\_LINK

[Description]

Specifies the number of lanes of an MIPI RX link.

[Definition]

#define MAX\_LANE\_NUM\_PER\_LINK 2

[Chip Difference]

None

[Note]

The link is a software concept. A logical link is split into two links of the software.

[See Also]

None

# MIPI\_LANE\_NUM

[Description]

Specifies the maximum number of lanes supported by the MIPI device of the MIPI RX.

[Definition]

Hi3559A V100ES/Hi3559A V100:

#define MIPI\_LANE\_NUM

| #define MIPI_LANE_NUM | (MAX_LANE_NUM_PER_LINK * 4) |
|-----------------------|-----------------------------|
| Hi3519A V100:         |                             |
| #define MIPI_LANE_NUM | 8                           |
| Hi3516C V500:         |                             |
| #define MIPI_LANE_NUM | 4                           |
| Hi3516E V200:         |                             |
| #define MIPI_LANE_NUM | 2                           |
| Hi3516E V300:         |                             |



[Chip Difference]

None

[Note]

None

[See Also]

None

# LVDS\_LANE\_NUM

[Description]

Specifies the maximum number of lanes supported by the LVDS device of the MIPI RX.

[Definition]

Hi3559A V100ES/Hi3559A V100:

| #define LVDS_LANE_NUM | COMBO_MAX_LANE_NUM |
|-----------------------|--------------------|
| Hi3519A V100:         |                    |
| #define LVDS_LANE_NUM | 12                 |
| Hi3516C V500:         |                    |
| #define LVDS_LANE_NUM | 4                  |
| Hi3516E V200:         |                    |
| #define LVDS_LANE_NUM | 2                  |
| Hi3516E V300:         |                    |
| #define LVDS_LANE_NUM | 4                  |

## [Chip Difference]

None

[Note]

None

[See Also]

None

# SLVS\_LANE\_NUM

[Description]

Specifies the maximum number of lanes supported by the SLVS devices.

[Definition]

Hi3559A V100ES/Hi3559A V100:

#define SLVS LANE NUM 8



Hi3519A V100:

#define SLVS\_LANE\_NUM

[Chip Difference]

None

[Note]

None

[See Also]

None

# COMS\_MAX\_DEV\_NUM

[Description]

Specifies the maximum number of supported parallel devices.

[Definition]

Hi3559A V100:

#define COMS\_MAX\_DEV\_NUM

[Chip Difference]

None

[Note]

None

[See Also]

None

# COMBO\_MAX\_LINK\_NUM

[Description]

Specifies the maximum number of links supported by the MIPI RX.

[Definition]

Hi3559A V100ES/Hi3559A V100:

#define COMBO\_MAX\_LINK\_NUM 8

[Chip Difference]

None

[Note]

None

[See Also]

None



# COMBO\_MAX\_DEV\_NUM

[Description]

Specifies the number of the MIPI RX devices.

[Definition]

Hi3559A V100ES:

#define COMBO MAX DEV NUM (MIPI RX MAX DEV NUM + SLVS MAX DEV NUM)

#### Hi3559A V100/Hi3519A V100/Hi3516C V500/Hi3516E V200:

#define COMBO\_MAX\_DEV\_NUM MIPI\_RX\_MAX\_DEV\_NUM

## [Chip Difference]

| Chip                          | Number of MIPI RX Devices                |
|-------------------------------|------------------------------------------|
| Hi3559A V100ES                | (MIPI_RX_MAX_DEV_NUM + SLVS_MAX_DEV_NUM) |
| Hi3559A<br>V100/Hi3519A V100/ | MIPI_RX_MAX_DEV_NUM                      |
| Hi3516C<br>V500/H3516E V200   |                                          |

## [Note]

- For Hi3559A V100ES, the IDs of MIPI and SLVS devices are unified.
- For Hi3559A V100/Hi3519A V100, the IDs of MIPI and SLVS devices are independent.

[See Also]

None

## WDR\_VC\_NUM

[Description]

Specifies the maximum number of supported virtual channels.

[Definition]

Hi3559A V100ES/Hi3559A V100/Hi3519A V100/Hi3516C V500:

#define WDR VC NUM

Hi3516E V300:

#define WDR\_VC\_NUM

Hi3516E V200/Hi3518E V300:

#define WDR VC NUM 2

[Chip Difference]



None

[Note]

None

[See Also]

None

# SYNC\_CODE\_NUM

[Description]

Defines the number of sync codes of per virtual channel of the LVDS.

[Definition]

## Hi3559A V100ES/Hi3559A V100/Hi3519A V100/Hi3516C V500:

```
#define SYNC_CODE_NUM 4

Hi3516EV300:

#define SYNC_CODE_NUM 2

Hi3516EV200/Hi3518E V300:

#define SYNC_CODE_NUM 2
```

## [Chip Difference]

None

[Note]

None

[See Also]

None

# lane\_divide\_mode\_t

[Description]

Defines the lane distribution of the MIPI RX.

[Definition]

## Hi3559A V100ES:

```
typedef enum
{
    LANE_DIVIDE_MODE_0 = 0,
    LANE_DIVIDE_MODE_1 = 1,
    LANE_DIVIDE_MODE_2 = 2,
    LANE_DIVIDE_MODE_3 = 3,
    LANE_DIVIDE_MODE_4 = 4,
    LANE_DIVIDE_MODE_5 = 5,
```

```
LANE_DIVIDE_MODE_6 = 6,

LANE_DIVIDE_MODE_7 = 7,

LANE_DIVIDE_MODE_8 = 8,

LANE_DIVIDE_MODE_9 = 9,

LANE_DIVIDE_MODE_BUTT

} lane_divide_mode_t;
```

#### Hi3559A V100:

```
typedef enum
{
   LANE_DIVIDE_MODE_0 = 0,
   LANE_DIVIDE_MODE_1 = 1,
   LANE_DIVIDE_MODE_2 = 2,
   LANE_DIVIDE_MODE_3 = 3,
   LANE_DIVIDE_MODE_4 = 4,
   LANE_DIVIDE_MODE_5 = 5,
   LANE_DIVIDE_MODE_6 = 6,
   LANE_DIVIDE_MODE_7 = 7,
   LANE_DIVIDE_MODE_8 = 8,
   LANE_DIVIDE_MODE_9 = 9,
   LANE_DIVIDE_MODE_A = 0xA,
   LANE_DIVIDE_MODE_B = 0xB,
   LANE_DIVIDE_MODE_B = 0xB,
   LANE_DIVIDE_MODE_BUTT
} lane_divide_mode_t;
```

#### Hi3519A V100:

```
typedef enum
{
    LANE_DIVIDE_MODE_0 = 0,
    LANE_DIVIDE_MODE_1 = 1,
    LANE_DIVIDE_MODE_2 = 2,
    LANE_DIVIDE_MODE_3 = 3,
    LANE_DIVIDE_MODE_4 = 4,
    LANE_DIVIDE_MODE_5 = 5,
    LANE_DIVIDE_MODE_6 = 6,
    LANE_DIVIDE_MODE_BUTT
} lane_divide_mode_t;
```

#### Hi3516C V500:

```
typedef enum
{
    LANE_DIVIDE_MODE_0 = 0,
    LANE_DIVIDE_MODE_1 = 1,
    LANE_DIVIDE_MODE_BUTT
```



```
} lane_divide_mode_t;
```

#### Hi3516E V200:

```
typedef enum
{
    LANE_DIVIDE_MODE_0 = 0,
    LANE_DIVIDE_MODE_BUTT
} lane_divide_mode_t;
```

## [Chip Difference]

| Chip           | Lane Distribution of the MIPI RX         |
|----------------|------------------------------------------|
| Hi3559A V100ES | [LANE_DIVIDE_MODE_0, LANE_DIVIDE_MODE_9] |
| Hi3559A V100   | [LANE_DIVIDE_MODE_0, LANE_DIVIDE_MODE_B] |
| Hi3519A V100   | [LANE_DIVIDE_MODE_0, LANE_DIVIDE_MODE_6] |
| Hi3516C V500   | [LANE_DIVIDE_MODE_0, LANE_DIVIDE_MODE_1] |
| Hi3516E V200   | LANE_DIVIDE_MODE_0                       |

## [Note]

Only the MIPI requires the lane distribution setting.

[See Also]

HI\_MIPI\_SET\_HS\_MODE

# input\_mode\_t

## [Description]

Specifies the MIPI RX input modes.

## [Definition]

```
typedef enum
  INPUT_MODE_MIPI = 0x0,
                                    /* mipi * /
  INPUT_MODE_SUBLVDS = 0x1,
                                    /* SUB LVDS * /
  INPUT_MODE_LVDS
                    = 0x2,
                                    /* LVDS * /
                    = 0x3,
  INPUT MODE HISPI
                                    /* HISPI * /
                    = 0x4,
  INPUT MODE SLVS
                                    /* SLVS * /
  INPUT_MODE_CMOS
                    = 0x5,
                                    /* CMOS * /
                    = 0x6,
  INPUT MODE BT601
                                    /* BT601 * /
  INPUT MODE BT656
                      = 0x7,
                                     /* BT656 * /
  INPUT MODE BT1120
                    = 0x8,
                                     /* BT1120 * /
  INPUT MODE BYPASS
                                     /* MIPI Bypass * /
                      = 0x9,
  INPUT_MODE_LVDS_EX
                                     /* LVDS EX * /
                      = 0xA,
```



```
INPUT_MODE_BUTT
} input_mode_t;
```

#### [Chip Difference]

None

#### [Note]

- For Hi3559A V100: When the input interface is a parallel device (such as INPUT\_MODE\_CMOS, INPUT\_MODE\_BT601, INPUT\_MODE\_BT656, or INPUT\_MODE\_BT1120), only a number of COMS\_MAX\_DEV\_NUM channels are supported. Channels 0 and 1 can be set as required, while channel 2 must be set.
- For Hi3559A V100: When channel 2 is set to INPUT\_MODE\_BT601 or INPUT\_MODE\_BT656, lane 8-lane 11 cannot be used as other interfaces. When channel 2 is set to INPUT\_MODE\_CMOS or INPUT\_MODE\_BT1120, lane 8-lane 15 cannot be used as other interfaces.
- For Hi3519A V100: When the input mode is INPUT\_MODE\_BT601 or INPUT\_MODE\_BT656 and MIPI device 0 or 1 is used, the pins of channel 0 are multiplexed with lane 8–lane 11, and the pins of channel 1 are multiplexed with lane 4–lane 7.
- For Hi3519A V100: When the input mode is INPUT\_MODE\_BT1120, only MIPI device 0 can be used, and the pins of channel 0 are multiplexed with lane 4–lane 11.

[See Also]

None

# mipi\_data\_rate\_t

[Description]

Defines the input rate of the MIPI RX and SLVS.

#### [Definition]

#### [Chip Difference]

| Chip                         | MIPI_DATA_RATE_X2 Supported or Not |
|------------------------------|------------------------------------|
| Hi3559A V100ES               | Supported by MIPI0 and SLVS6       |
| Hi3559A V100<br>Hi3519A V100 | Supported by MIPI0 and SLVS6       |
| Hi3516C V500<br>Hi3516E V200 | Not supported                      |

[Note]

None

[See Also]

None

# img\_rect\_t

[Description]

Defines MIPI crop attributes.

#### [Definition]

```
typedef struct
{
   int x;
   int y;
   unsigned int width;
   unsigned int height;
} img_rect_t;
```

## [Member]

| Member | Description                                      |
|--------|--------------------------------------------------|
| X      | Horizontal coordinate of the crop start position |
| у      | Vertical coordinate of the crop start position   |
| width  | Crop width (in pixels)                           |
| height | Crop height (in pixels)                          |

## [Chip Difference]

None

[Note]

The vertical coordinate of the SLVS-EC cropping must be greater than or equal to the number of valid lines of the sensor output.

[See Also]

None

# slvs\_lane\_rate\_t

[Description]

Defines the input rate of the SLVS lane.



#### [Definition]

MIPI User Guide

## [Chip Difference]

None

[Note]

None

[See Also]

None

# slvs\_err\_check\_mode\_t

[Description]

Defines the SLVS error check mode.

## [Syntax]

```
typedef enum
{
    SLVS_ERR_CHECK_MODE_NONE = 0x0,
    SLVS_ERR_CHECK_MODE_CRC = 0x1,
    SLVS_ERR_CHECK_MODE_ECC_2BYTE = 0x2,
    SLVS_ERR_CHECK_MODE_ECC_4BYTE = 0x3,

SLVS_ERR_CHECK_MODE_BUTT
} slvs_err_check_mode_t;
```

## [Member]

| Member                        | Description          |
|-------------------------------|----------------------|
| SLVS_ERR_CHECK_MODE_NONE      | ECC and CRC disabled |
| SLVS_ERR_CHECK_MODE_CRC       | CRC enabled          |
| SLVS_ERR_CHECK_MODE_ECC_2BYTE | 2-byte ECC enabled   |
| SLVS_ERR_CHECK_MODE_ECC_4BYTE | 4-byte ECC enabled   |

[Difference]

None



[Note]

The ECC and CRC functions of the SLVS are mutually exclusive and cannot be enabled at the same time.

[See Also]

slvs\_dev\_attr\_t

## data\_type\_t

[Description]

Defines the data type for transmission.

[Definition]

Hi3519A V100/Hi3516C V500:

```
typedef enum
{
    DATA_TYPE_RAW_8BIT = 0,
    DATA_TYPE_RAW_10BIT,
    DATA_TYPE_RAW_12BIT,
    DATA_TYPE_RAW_14BIT,
    DATA_TYPE_RAW_16BIT,
    DATA_TYPE_YUV420_8BIT_NORMAL,
    DATA_TYPE_YUV420_8BIT_LEGACY,
    DATA_TYPE_YUV422_8BIT,
    DATA_TYPE_YUV422_PACKED,
    DATA_TYPE_BUTT,
} data_type_t;
```

## Other chips:

```
typedef enum
{
    DATA_TYPE_RAW_8BIT = 0,
    DATA_TYPE_RAW_10BIT,
    DATA_TYPE_RAW_12BIT,
    DATA_TYPE_RAW_14BIT,
    DATA_TYPE_RAW_16BIT,
    DATA_TYPE_RAW_16BIT,
    DATA_TYPE_YUV420_8BIT_NORMAL,
    DATA_TYPE_YUV420_8BIT_LEGACY,
    DATA_TYPE_YUV422_8BIT,
    DATA_TYPE_BUTT
} data_type_t
```

[Member]





| Member                       | Description                                                            |
|------------------------------|------------------------------------------------------------------------|
| DATA_TYPE_RAW_8BIT           | 8-bit raw data                                                         |
| DATA_TYPE_RAW_10BIT          | 10-bit raw data                                                        |
| DATA_TYPE_RAW_12BIT          | 12-bit raw data                                                        |
| DATA_TYPE_RAW_14BIT          | 14-bit raw data                                                        |
| DATA_TYPE_RAW_16BIT          | 16-bit raw data                                                        |
| DATA_TYPE_YUV420_8BIT_NORMAL | 8-bit YUV420 data, normal format                                       |
| DATA_TYPE_YUV420_8BIT_LEGACY | 8-bit YUV420 data, legacy format                                       |
| DATA_TYPE_YUV422_8BIT        | 8-bit YUV422 data                                                      |
| DATA_TYPE_YUV422_PACKED      | YUV422 data is packed and received in 16-bit raw format over the MIPI. |

# [Chip Difference]

| Member                    | Data type supported                 |
|---------------------------|-------------------------------------|
| Hi3559A V100ES            | DATA_TYPE_RAW_8BIT                  |
|                           | • DATA_TYPE_RAW_10BIT               |
|                           | DATA_TYPE_RAW_12BIT                 |
|                           | • DATA_TYPE_RAW_14BIT               |
|                           | DATA_TYPE_RAW_16BIT                 |
| Hi3559A V100              | All, except DATA_TYPE_YUV422 PACKED |
| Hi3519A V100/Hi3516C V500 | All                                 |
| Hi3516E V200              | DATA_TYPE_RAW_8BIT                  |
|                           | DATA_TYPE_RAW_10BIT                 |
|                           | DATA_TYPE_RAW_12BIT                 |
|                           | DATA_TYPE_RAW_14BIT                 |

[Note]

None

[See Also]

None

# $mipi\_wdr\_mode\_t$

[Description]

Defines the MIPI WDR mode.



#### [Definition]

#### [Member]

| Member                    | Description                                                                                              |
|---------------------------|----------------------------------------------------------------------------------------------------------|
| HI_MIPI_WDR_MODE_NON<br>E | Linear mode                                                                                              |
| HI_MIPI_WDR_MODE_VC       | The virtual channel in the packet header is used to differentiate long and short exposure frames.        |
| HI_MIPI_WDR_MODE_DT       | The self-defined data type in the packet header is used to differentiate long and short exposure frames. |
| HI_MIPI_WDR_MODE_DOL      | DOL-mode WDR. A pixel after the packet header is used to differentiate long and short exposure frames.   |

## [Chip Difference]

None

[Note]

None

[See Also]

None

# mipi\_dev\_attr\_t

[Description]

Defines the attributes of the MIPI device.

## [Definition]

```
typedef struct
{
    data_type_t input_data_type;
    mipi_wdr_mode_t wdr_mode;
    short lane_id[MIPI_LANE_NUM];
    union
    {
```



```
short data_type[WDR_VC_NUM];
};
}mipi_dev_attr_t;
```

#### [Member]

| Member          | Description                                                                                                                        |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------|
| input_data_type | Data type for transmission                                                                                                         |
| lane_id         | Mapping between the TX end (sensor) and RX end (MIPI RX) lanes  This member is set to -1 for unused lanes.                         |
| wdr_mode        | MIPI WDR mode                                                                                                                      |
| data_type       | Data type corresponding to different exposure length data. When wdr_mode is HI_MIPI_WDR_MODE_DT, data_type needs to be configured. |

#### [Chip Difference]

None

#### [Note]

- In 2L+2L mode of the Hi3516C V500, MIPI CH1 has only two valid lanes, which are connected to lane 1 and lane 3 of the PHY, respectively. Therefore, **lane\_id** must be set to  $\{0, 1, -1, -1\}$  or  $\{1, 3, -1, -1\}$ . If they are cross-connected, **lane\_id** must be set to  $\{1, 0, -1, -1\}$  or  $\{3, 1, -1, -1\}$ .
- Hi3516E V200 and Hi3518E V300 have only two lanes, namely, lane 0 and lane 2. Therefore, **lane\_id** must be set to  $\{0, 2, -1, -1\}$ .
- Hi3516E V300 has four lanes. When a 2-lane sensor is connected, lane 0 and lane 1 are used and lane\_id must be set to {0, 1, -1, -1}. When a 4-lane sensor is connected, lane\_id must be set to {0, 1, 2, 3}.

#### [See Also]

- data\_type\_t
- mipi\_wdr\_mode\_t
- HI\_MIPI\_SET\_DEV\_ATTR

## wdr\_mode\_t

#### [Description]

Defines the LVDS WDR mode.

#### [Definition]

```
typedef enum
{
    HI_WDR_MODE_NONE = 0x0,
    HI_WDR_MODE_2F = 0x1,
```

```
HI_WDR_MODE_3F = 0x2,
HI_WDR_MODE_4F = 0x3,
HI_WDR_MODE_DOL_2F = 0x4,
HI_WDR_MODE_DOL_3F = 0x5,
HI_WDR_MODE_DOL_4F = 0x6,
HI_WDR_MODE_BUTT
} wdr_mode_t;
```

## [Member]

| Member             | Description              |
|--------------------|--------------------------|
| HI_WDR_MODE_NONE   | Linear mode              |
| HI_WDR_MODE_2F     | 2-to-1 WDR mode          |
| HI_WDR_MODE_3F     | 3-to-1 WDR mode          |
| HI_WDR_MODE_4F     | 4-to-1 WDR mode          |
| HI_WDR_MODE_DOL_2F | DOL mode with 2-to-1 WDR |
| HI_WDR_MODE_DOL_3F | DOL mode with 3-to-1 WDR |
| HI_WDR_MODE_DOL_4F | DOL mode with 4-to-1 WDR |

# [Chip Difference]

| Chip                         | WDR Mode                                |
|------------------------------|-----------------------------------------|
| Hi3559A V100ES/              | All modes are supported.                |
| Hi3559A V100/                |                                         |
| Hi3519A V100/                |                                         |
| Hi3516C V500                 |                                         |
| Hi3516E V200/Hi3518E<br>V300 | The 2-to-1 WDR frame mode is supported. |
| Hi3516E V300                 | All modes are supported.                |

## [Note]

- To enable the DOL WDR mode, select HI\_WDR\_MODE\_DOL\_2F, HI\_WDR\_MODE\_DOL\_3F, or HI\_WDR\_MODE\_DOL\_4F.
- To enable the built-in WDR mode or the multi-frame combination WDR mode, select HI\_WDR\_MODE\_NONE.

[See Also]

None

# lvds\_sync\_mode\_t

[Description]

Defines the LVDS sync mode.

## [Definition]

## Table 1-6 LVDS sync mode

| sync_mode          | Sync Mode                                                          |
|--------------------|--------------------------------------------------------------------|
| LVDS_SYNC_MODE_SOF | SOF, EOF, SOL, and EOL<br>See Figure 1-1.                          |
| LVDS_SYNC_MODE_SAV | invalid SAV, invalid EAV, valid SAV, and valid EAV See Figure 1-2. |

# [Chip Difference]

None

[Note]

None

[See Also]

None

## lvds\_bit\_endian\_t

[Description]

Defines the bit endian mode.

## [Definition]

```
typedef enum
{
    LVDS_ENDIAN_LITTLE = 0x0,
    LVDS_ENDIAN_BIG = 0x1,
    LVDS_ENDIAN_BUTT
} lvds_bit_endian_t;
```

## [Chip Difference]



None

[Note]

None

[See Also]

None

# lvds\_vsync\_type\_t

[Description]

Defines the LVDS vsync type.

## [Definition]

```
typedef enum
{
    LVDS_VSYNC_NORMAL = 0x00,
    LVDS_VSYNC_SHARE = 0x01,
    LVDS_VSYNC_HCONNECT = 0x02,
    LVDS_VSYNC_BUTT
} lvds_vsync_type_t;
```

## [Member]

| Member              | Description                                                                                                                                           |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| LVDS_VSYNC_NORMAL   | Long and short exposure frames have independent SOF-EOF, independent SOL-EOL, invalid SAV-invalid EAV, or valid SAV-valid EAV.                        |
| LVDS_VSYNC_SHARE    | Long and short exposure frames share one pair of SOF-EOF identifiers. The first several rows of short exposure frames are filled with fixed values.   |
| LVDS_VSYNC_HCONNECT | Long and short exposure frames share one pair of SAV-EAV identifiers. There is a fixed period of blanking between the long and short exposure frames. |

## • LVDS\_VSYNC\_SHARE sync modes:

| SOF | Long Exposure | EOL | Horizontal<br>Blanking | SOL | Padding        | EOL | Horizo<br>ntal<br>Blanki<br>ng |
|-----|---------------|-----|------------------------|-----|----------------|-----|--------------------------------|
| SOL |               |     |                        |     | Short Exposure |     |                                |



|     | Padding |     |   |     |       |     |   |
|-----|---------|-----|---|-----|-------|-----|---|
|     |         |     |   |     |       | EOF |   |
| SOV | V.BLK   | EOV | - | SOV | V.BLK | EOV | - |
|     |         |     |   |     |       |     |   |

# • LVDS\_VSYNC\_HCONNECT sync modes:

| SAV | Long Exposure frame  V.BLK | Horizontal<br>Blanking<br>(fixed<br>period) | V.BLK Short ExposureFrame1 V.BLK | Horizontal<br>Blanking<br>(fixed<br>period) | V.BLK  Short Exposure Frame2 | EAV | Horizontal<br>Blanking |
|-----|----------------------------|---------------------------------------------|----------------------------------|---------------------------------------------|------------------------------|-----|------------------------|
|     | V.BLK                      |                                             |                                  |                                             |                              |     | -                      |

[Chip Difference]

None

[Note]

None

[See Also]

 $lvds\_vsync\_attr\_t$ 

# lvds\_vsync\_attr\_t

[Description]

Defines the LVDS vsync parameter.

[Definition]

```
typedef struct
{
    lvds_vsync_type_t sync_type;

    unsigned short hblank1;
    unsigned short hblank2;
} lvds_vsync_attr_t;
```



[Chip Difference]

None

[Note]

When **sync\_type** is set to LVDS\_VSYNC\_HCONNECT, **hblank1** and **hblank2** must be configured to indicate the length of the blanking region of Hconnect.

[See Also]

lvds\_vsync\_type\_t

# lvds\_fid\_type\_t

[Description]

Defines the frame ID type.

## [Definition]

#### [Member]

| Member           | Description                                                                                                                                                                                             |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LVDS_FID_NONE    | Frame ID is not used.                                                                                                                                                                                   |
| LVDS_FID_IN_SAV  | Frame ID will be inserted at the fourth field of the SAV. For the sync codes of the four fields of the DOL, fid_type should be set to LVDS_FID_IN_SAV.                                                  |
| LVDS_FID_IN_DATA | As the frame information column, the frame ID will be inserted before the first pixel after the sync code. For the sync codes of the five fields of the DOL, fid_type should be set to LVDS_FID_IN_DATA |

[Chip Difference]

None

[Note]

None

[See Also]

None



# lvds\_fid\_attr\_t

[Description]

Defines the frame ID configuration information.

## [Definition]

```
typedef struct
{
    lvds_fid_type_t fid_type;
    HI_BOOL output_fil;
} lvds_fid_attr_t;
```

## [Member]

| Member     | Description                                                                                                                                           |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| fid_type   | Frame ID type in LVDS DOL mode                                                                                                                        |
| output_fil | The frame information line will be outputted right after V-Blanking in DOL mode. The frame ID is the first pixel value of the frame information line. |
|            | The frame information line does not contain valid video data:                                                                                         |
|            | • If output_fil is set to <b>HI_TRUE</b> , the frame information line will be outputted to the back-end device.                                       |
|            | • If output_fil is set to <b>HI_FALSE</b> , MIPI RX will abandon this frame information line.                                                         |

## [Chip Difference]

None

[Note]

None

[See Also]

lvds\_fid\_type\_t

# mipi\_clk\_mode\_t

## [Description]

Defines the clock sharing mode when the LVDS mode involves multiple PHYs. The clock of the PHY with the minimum number where the lane is located can be used. Alternatively, each PHY can use its own clock.

#### [Syntax]

```
typedef enum
{
    MIPI_CLK_MODE_SHARE = 0x0,
    MIPI_CLK_MODE_SEPARATE = 0x1,
```



```
MIPI_CLK_MODE_BUTT
} mipi_clk_mode_t;
```

## [Member]

| Member                 | Description                        |
|------------------------|------------------------------------|
| MIPI_CLK_MODE_SHARE    | The PHYs share the clock of a PHY. |
| MIPI_CLK_MODE_SEPARATE | Each PHY uses its own clock.       |

[Difference]

None

[Note]

None

[See Also]

lvds\_dev\_attr\_ex\_t

# lvds\_lane\_work\_mode\_t

## [Description]

Defines the arrival mode of the synchronization code of the LVDS lane.

## [Syntax]

```
typedef enum
{
    LVDS_LANE_WORK_MODE_SYNC = 0x0,
    LVDS_LANE_WORK_MODE_ASYNC = 0x1,
    LVDS_LANE_WORK_MODE_BUTT
} lvds_lane_work_mode_t;
```

#### [Member]

| Member                    | Description                                                       |
|---------------------------|-------------------------------------------------------------------|
| LVDS_LANE_WORK_MODE_SYNC  | The synchronization code of the LVDS lane arrives synchronously.  |
| LVDS_LANE_WORK_MODE_ASYNC | The synchronization code of the LVDS lane arrives asynchronously. |

[Difference]

None

[Note]

None



[See Also]

lvds\_lane\_work\_attr\_t

# lvds\_lane\_work\_attr\_t

[Description]

Defines the working attributes of the synchronization code of the LVDS lane.

## [Syntax]

#### [Member]

| Member             | Description                                        |
|--------------------|----------------------------------------------------|
| lane_work_mode     | Working mode of the lane synchronization code      |
| sensor_valid_width | Number of pixels in a line of data packets (RAW H) |

[Difference]

None

[Note]

None

[See Also]

lvds\_dev\_attr\_ex\_t

# lvds\_dev\_attr\_t

#### [Description]

Defines the device attributes supported by the LVDS, SubLVDS, and HiSPi interfaces.

## [Definition]



```
short lane_id[LVDS_LANE_NUM];
unsigned short sync_code[LVDS_LANE_NUM][WDR_VC_NUM][SYNC_CODE_NUM];
} lvds_dev_attr_t;
```

## [Member]

| Member           | Description                                                                                                                                                                                         |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| input_data_type  | Data type for transmission                                                                                                                                                                          |
| wdr_mode         | WDR mode                                                                                                                                                                                            |
| sync_mode        | LVDS sync mode                                                                                                                                                                                      |
| vsync_ attr      | vsync type. When <b>wdr_mod</b> is set to DOL mode and <b>sync_mode</b> is set to <b>LVDS_SYNC_MODE_SAV</b> , the vsync type must be configured.                                                    |
| fid_attr         | Frame ID type. When <b>wdr_mod</b> is set to DOL mode and <b>sync_mode</b> is set to <b>LVDS_SYNC_MODE_SAV</b> , the frame ID type must be configured.                                              |
| data_endian      | Endian mode of the data                                                                                                                                                                             |
| sync_code_endian | Endian mode of the sync codes                                                                                                                                                                       |
| lane_id          | Lane mapping between the TX end (sensor) and the RX end (MIPI RX)  The ID of each unused lane is set to -1.                                                                                         |
|                  | See section 1.8.1 "How Do I Configure a Lane ID?" for details about the configuration of the lane ID.                                                                                               |
| sync_code        | Each virtual channel has four sync codes. According to the sync mode, they stands for the sync codes of SOF, EOF, SOL, and EOL or sync codes of invalid SAV, invalid EAV, valid SAV, and valid EAV. |

# [Chip Difference]

None

[Note]

When this structure is used, the SLVS clock is shared, and the LVDS lane synchronization code arrives synchronously.

## [See Also]

- wdr\_mode\_t
- lvds\_sync\_mode\_t
- data\_type\_t
- lvds\_bit\_endian\_t
- lvds\_vsync\_type\_t
- lvds\_fid\_type\_t



#### HI\_MIPI\_SET\_DEV\_ATTR

# lvds\_dev\_attr\_ex\_t

[Description]

Defines the advanced device attributes supported by the LVDS, sub-LVDS, and HiSPi interfaces.

## [Syntax]

#### [Member]

| Member         | Description                |
|----------------|----------------------------|
| clk_mode       | Data type for transmission |
| lvds_attr      | WDR mode                   |
| lane_work_attr | LVDS sync mode             |

## [Difference]

None

[Note]

None

#### [See Also]

- wdr\_mode\_t
- lvds\_sync\_mode\_t
- data\_type\_t
- lvds\_bit\_endian\_t
- lvds\_vsync\_type\_t
- lvds\_fid\_type\_t
- HI\_MIPI\_SET\_DEV\_ATTR

# slvs\_dev\_attr\_t

## [Description]

Defines the attributes of the SLVS device.

[Definition]



## • Other chips:

## • Hi3559A V100:

#### [Member]

| Member             | Description                                                                                                      |
|--------------------|------------------------------------------------------------------------------------------------------------------|
| input_data_type    | Data type for transmission                                                                                       |
| wdr_mode           | WDR mode                                                                                                         |
| lane_rate          | SLVS lane rate                                                                                                   |
| sensor_valid_width | Number of pixels in a line of data packets (RAW H)                                                               |
| lane_id            | Mapping between the TX-end (sensor) lane and the RX-end (SLVS) lane The lane_id of the unused lane is set to -1. |
| err_check_mode     | SLVS CRC/ECC mode. The setting must match that for the sensor.                                                   |

## [Chip Difference]

| Chip            | slvs_dev_attr_t        |
|-----------------|------------------------|
| Hi3559A V100ES/ | Supported              |
| Hi3559A V100/   |                        |
| Hi3519A V100    |                        |
| Hi3516C V500/   | SLVS is not supported. |
| Hi3616E V200    |                        |



#### [Note]

MIPI User Guide

The SLVS device supports only the linear mode and the 2-to-1 WDR mode.

## [See Also]

- data\_type\_t
- slvs\_lane\_rate\_t
- HI\_MIPI\_SET\_DEV\_ATTR

# phy\_cmv\_mode\_t

## [Description]

Defines the PHY common-mode voltage mode.

## [Definition]

```
typedef enum
{
    PHY_CMV_GE1200MV = 0x00,
    PHY_CMV_LT1200MV = 0x01,
    PHY_CMV_BUTT
} phy_cmv_mode_t;
```

#### [Member]

| Member           | Description                                                      |
|------------------|------------------------------------------------------------------|
| PHY_CMV_GE1200MV | The PHY common-mode voltage is greater than or equal to 1200 mV. |
| PHY_CMV_LT1200MV | The PHY common-mode voltage is less than 1200 mV.                |

## [Chip Difference]

None

[Note]

None

[See Also]

None

# phy\_cmv\_t

## [Description]

Defines the configuration information of the PHY common-mode voltage.

## [Definition]

typedef struct



```
combo_dev_t devno;
phy_cmv_mode_t cmv_mode;
} phy_cmv_t;
```

#### [Member]

| Member   | Description                      |
|----------|----------------------------------|
| devno    | ID of the MIPI RX device         |
| cmv_mode | Voltage mode of the PHY function |

## [Chip Difference]

None

[Note]

None

[See Also]

- phy\_cmv\_mode\_t
- HI\_MIPI\_SET\_PHY\_CMVMODE

# combo\_dev\_attr\_t

[Description]

Defines the combo device attributes. The MIPI RX device is called the combo device because the MIPI RX can interwork with the CSI-2, LVDS, and HiSPi timings.

[Definition]

• Other chips:

#### • Hi3559A V100:

typedef struct

## [Member]

| Member       | Description                                                                                                     |
|--------------|-----------------------------------------------------------------------------------------------------------------|
| devno        | Numbers of MIPI RX and SLVS devices                                                                             |
| input_mode   | Input interface type                                                                                            |
| data_rate    | Interface transmission rate                                                                                     |
| img_rect     | Crop region of the image                                                                                        |
| mipi_attr    | If <b>input_mode</b> is set to <b>INPUT_MODE_MIPI</b> , <b>mipi_attr</b> must be configured.                    |
| lvds_attr    | If input_mode is set to INPUT_MODE_SUBLVDS, INPUT_MODE_LVDS, or INPUT_MODE_HISPI, lvds_attr must be configured. |
| slvs_attr    | If input_mode is set to INPUT_MODE_SLVS, slvs_attr must be configured.                                          |
| lvds_attr_ex | If input_mode is set to INPUT_MODE_LVDS_EX, lvds_attr_ex must be configured.                                    |

# [Chip Difference]

| Chip            | combo_dev_attr_t       |
|-----------------|------------------------|
| Hi3559A V100ES/ | Supported              |
| Hi3559A V100/   |                        |
| Hi3519A V100/   |                        |
| Hi3516C V500/   | SLVS is not supported. |
| Hi3516E V200    |                        |



[Note]

None

[See Also]

None

### HI\_MIPI\_TX\_IOC\_MAGIC

[Description]

Defines the magic number of MIPI RX ioctl in a command.

[Definition]

```
#define HI_MIPI_TX_IOC_MAGIC 't'
```

[Member]

None

[Chip Difference]

None

[Note]

None

[See Also]

None

# LANE\_MAX\_NUM

[Description]

Defines the maximum number of lanes supported by the MIPI TX.

[Definition]

```
#define LANE_MAX_NUM
```

[Chip Difference]

None

[Note]

None

[See Also]

None

# output\_mode\_t

[Description]

Defines the MIPI TX output mode.



#### [Definition]

### [Chip Difference]

None

[Note]

None

[See Also]

None

## video\_mode\_t

[Description]

Defines the MIPI TX video mode.

#### [Definition]

### [Chip Difference]

None

[Note]

None

[See Also]

None

# output\_format\_t

[Description]

Defines the MIPI TX output format.

[Definition]

typedef enum



# [Chip Difference]

None

[Note]

None

[See Also]

None

# sync\_info\_t

### [Description]

Defines the synchronization information of an MIPI TX device.

#### [Definition]

```
typedef struct
{
  unsigned short vid_pkt_size;
  unsigned short vid_hsa_pixels;
  unsigned short vid_hbp_pixels;
  unsigned short vid_hline_pixels;
  unsigned short vid_vsa_lines;
  unsigned short vid_vsp_lines;
  unsigned short vid_vfp_lines;
  unsigned short vid_active_lines;
  unsigned short edpi_cmd_size;
} sync_info_t;
```

| Member         | Description                                         |  |  |  |
|----------------|-----------------------------------------------------|--|--|--|
| vid_pkt_size   | Size of an RX packet                                |  |  |  |
| vid_hsa_pixels | Number of pixels in the line sync pulse region      |  |  |  |
| vid_hbp_pixels | Number of pixels in the horizontal back porch (HBP) |  |  |  |

| Member           | Description                                                                                                                  |  |  |  |
|------------------|------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| vid_hline_pixels | Number of detected pixels in each line                                                                                       |  |  |  |
| vid_vsa_lines    | Number of detected frame sync pulse lines                                                                                    |  |  |  |
| vid_vbp_lines    | (umber of lines in the frame sync pulse vertical back porch VBP)                                                             |  |  |  |
| vid_vfp_lines    | Number of lines in the frame sync pulse vertical front porch (VFP)                                                           |  |  |  |
| vid_active_lines | Number of lines in the active area                                                                                           |  |  |  |
| edpi_cmd_size    | Number of bytes in the write memory command This parameter is invalid in Video mode, and is set to the HACT in Command mode. |  |  |  |

[Chip Difference]

None

[Note]

None

[See Also]

None

# combo\_dev\_cfg\_t

[Description]

Defines the attributes of an MIPI TX device.

#### [Definition]

```
typedef struct
  unsigned int
                     devno;
   short
                    lane id[LANE MAX NUM];
  output_mode_t
                   output_mode;
   video_mode_t
                    video_mode;
   output_format_t output_format;
   sync_info_t
                    sync_info;
   unsigned int
                     phy_data_rate;
   unsigned int
                     pixel_clk;
} combo_dev_cfg_t;
```

| Member        | Description                                                                                                                                                                                                |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| devno         | MIPI TX device ID                                                                                                                                                                                          |
| lane_id       | Lane mapping between the TX end (sensor) and RX end (MIPI RX).                                                                                                                                             |
|               | The value of unused lanes is set to –1.                                                                                                                                                                    |
| output_mode   | Output mode of an MIPI TX device                                                                                                                                                                           |
| video_mode    | Video mode of an MIPI TX device                                                                                                                                                                            |
| output_format | Output format of an MIPI TX device                                                                                                                                                                         |
| sync_info     | Synchronization information of an MIPI TX device                                                                                                                                                           |
| phy_data_rate | MIPI TX output rate. For details about the range, see the description of the lane rate range of each lane in MIPI TX high-speed mode in section "TX D-PHY" in the <i>Hi35xx xx Camera SoC Data Sheet</i> . |
| pixel_clk     | Pixel clock, in kHz                                                                                                                                                                                        |

[Chip Difference]

None

[Note]

None

[See Also]

None

# $cmd\_info\_t$

### [Description]

Defines the command data to be sent to an MIPI TX device.

### [Definition]

| Member | Description           |  |
|--------|-----------------------|--|
| devno  | MIPI TX device number |  |



| Member    | Description                                                                                                                                                                                                                             |  |  |  |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| devno     | MIPI TX device number                                                                                                                                                                                                                   |  |  |  |
| data_type | Command data type                                                                                                                                                                                                                       |  |  |  |
| cmd_size  | Command data size  Value range: (0, 200]  For a single command, when <b>cmd</b> is set to <b>NULL</b> , the lower eight bits correspond to data 1, and the upper eight bits correspond to data 2.                                       |  |  |  |
| cmd       | Pointer to command data  When the length of the command to be sent is within four bytes, this parameter can be set to NULL. When the length of the command to be sent exceeds four bytes, this parameter can be configured as required. |  |  |  |

[Chip Difference]

None

[Note]

None

[See Also]

None

# $get\_cmd\_info\_t$

### [Description]

Defines the command information sent to the MIPI TX device.

### [Syntax]

```
typedef struct
{
   unsigned int         devno;
   unsigned short         data_type;
   unsigned short         data_param;
   unsigned short         get_data_size;
unsigned char          * get_data;
} get_cmd_info_t;
```

| Member    | Description       |  |
|-----------|-------------------|--|
| devno     | MIPI TX device ID |  |
| data_type | Command data type |  |



| Member        | Description                                                                                                                                                         |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| devno         | MIPI TX device ID                                                                                                                                                   |
| data_param    | Data parameter. The lower eight bits define the first parameter and the upper eight bits define the second parameter. Set a bit to <b>0</b> if the bit is not used. |
| get_data_size | Expected number of data bytes to be obtained Value range: (0, 200]                                                                                                  |
| get_data      | Pointer to the obtained data storage address. The address needs to be allocated by the user.                                                                        |

[Difference]

None

[Note]

None

[See Also]

None

# 1.6 Parameter of the MIPI TX Module



This section applies only to Hi3516C V500.

### smooth

The **smooth** parameter implements smooth transition. Use this module as follows:

 On Linux, enable or disable the logic reset of the MIPI TX module when loading the MIPI TX driver.

To disable the logic reset: insmod hi\_mipi\_tx.ko smooth=1

To enable the logic reset: insmod hi\_mipi\_tx.ko smooth=0

• On Huawei LiteOS, enable or disable the logic reset of the MIPI TX module by transferring the **smooth** argument.

To disable the logic reset: int smooth=1; MIPI\_TX\_init(smooth)
To enable the logic reset: int smooth=0; MIPI\_TX\_init(smooth)



# 1.7 Proc Information

# 1.7.1 MIPI\_RX Proc Information

When MIPI RX works normally, the width and height in the proc information are stable and matched with those of the sensor output timing. In addition, the error interrupt count of MIPI RX is 0. If the value is not 0, check whether the attributes of MIPI RX are configured correctly.

### Hi3559A V100

### [Debugging Information]

| - 55 5                                              |              |           |              |             |           |  |  |  |  |  |
|-----------------------------------------------------|--------------|-----------|--------------|-------------|-----------|--|--|--|--|--|
| Module: [MIPI], Build Time: [May 23 2017, 10:04:19] |              |           |              |             |           |  |  |  |  |  |
| MIPI LANE DIVIDE MODE                               |              |           |              |             |           |  |  |  |  |  |
| MODE LANE DIVIDE                                    |              |           |              |             |           |  |  |  |  |  |
| 7 4+4+4+4                                           |              |           |              |             |           |  |  |  |  |  |
| MIPI DEV ATTR                                       |              |           |              |             |           |  |  |  |  |  |
| Devno WorkMode                                      | DataRate Dat | taType WI | RMode        | LinkId      | ImgX ImgY |  |  |  |  |  |
| ImgW ImgH                                           |              |           |              |             |           |  |  |  |  |  |
| 0 MIP                                               | I X1         | RAW12     | None         | 0, 1        | 0 0       |  |  |  |  |  |
| 3840 2160                                           |              |           |              |             |           |  |  |  |  |  |
|                                                     |              |           |              |             |           |  |  |  |  |  |
| MIPI LANE                                           | INFO         |           |              |             |           |  |  |  |  |  |
| Devno LaneC                                         | nt           | LaneID    |              |             |           |  |  |  |  |  |
| 0 4                                                 | 0, 1,        | 2, 3, -   | 1, -1, -1, - | -1          |           |  |  |  |  |  |
|                                                     |              |           |              |             |           |  |  |  |  |  |
| MIPI LINK                                           | INFO         |           |              |             |           |  |  |  |  |  |
| LinkIdx LaneCo                                      | unt LaneId   | PhyData0  | PhyData1     | AlignedData | a0        |  |  |  |  |  |
| AlignedData1 V                                      | /alidLane    |           |              |             |           |  |  |  |  |  |
| 0 2                                                 | 0, 1         | 0x0       | 0x0          | 0x0         | 0×0       |  |  |  |  |  |
| Invalid                                             |              |           |              |             |           |  |  |  |  |  |
| 1 2                                                 | 2, 3         | 0x0       | 0x0          | 0x0         | 0x0       |  |  |  |  |  |
| Invalid                                             |              |           |              |             |           |  |  |  |  |  |
| MIPI DETEC                                          | T INFO       |           |              |             |           |  |  |  |  |  |
| Devno VC widt                                       | h height     |           |              |             |           |  |  |  |  |  |
| 0 0 3840                                            | 2160         |           |              |             |           |  |  |  |  |  |
| 0 1 0                                               | 0            |           |              |             |           |  |  |  |  |  |
| 0 2 0                                               | 0            |           |              |             |           |  |  |  |  |  |
| 0 3 0                                               | 0            |           |              |             |           |  |  |  |  |  |
|                                                     |              |           |              |             |           |  |  |  |  |  |
| LVDS DETEC                                          | T INFO       |           |              |             |           |  |  |  |  |  |
| Devno VC widt                                       |              |           |              |             |           |  |  |  |  |  |
| 0 0 5480                                            |              |           |              |             |           |  |  |  |  |  |
| 0 1 0                                               |              |           |              |             |           |  |  |  |  |  |
| 0 2 0                                               |              |           |              |             |           |  |  |  |  |  |
| 0 2 0                                               | Ü            |           |              |             |           |  |  |  |  |  |

| 0 3               |            | 0        | 0        |             |        |           |             |          |
|-------------------|------------|----------|----------|-------------|--------|-----------|-------------|----------|
|                   |            |          |          |             |        |           |             |          |
|                   |            |          |          |             |        |           |             |          |
|                   | Lane       |          | height   |             |        |           |             |          |
| 0                 | 0          | 548      | 3689     |             |        |           |             |          |
| 0                 | 1          | 548      | 3689     |             |        |           |             |          |
| 0                 | 2          | 548      | 3689     |             |        |           |             |          |
| 0                 | 3          | 548      | 3689     |             |        |           |             |          |
| 0                 | 4          | 548      | 3689     |             |        |           |             |          |
| 0                 | 5          | 548      | 3689     |             |        |           |             |          |
| 0                 | 6          | 548      | 3689     |             |        |           |             |          |
| 0                 | 7          | 548      | 3689     |             |        |           |             |          |
| 0                 | 8          | 548      | 3689     |             |        |           |             |          |
| 0                 | 10         | 548      | 3689     |             |        |           |             |          |
| FON               |            | OII      |          | TNEO        |        |           |             |          |
|                   |            |          |          | INFO        |        |           | TO + O + 11 |          |
|                   |            |          |          |             | azrou  | tent as:  | [OutCnt cl  | ESCUNT   |
|                   |            |          | 12ESCUNT | d3EscCnt    | 0      | 0         | 0           | 0        |
| 0                 | 0          | 0        |          | 0           | 0      | 0         | 0           | 0        |
| 0                 | 0          | 0        |          |             | 0      | 0         | 0           | 0        |
| 1                 | 0          | 0        |          | 0           | 0      | 0         | 0           | 0        |
| 0                 | 0          | 0        |          |             |        |           |             |          |
| 2                 | 0          | 0        |          | 0           | 0      | 0         | 0           | 0        |
| 0                 | 0          | 0        |          |             |        |           |             |          |
| 3                 | 0          | 0        |          | 0           | 0      | 0         | 0           | 0        |
| 0                 | 0          | 0        |          |             |        |           |             |          |
| MIP               |            |          |          |             |        |           |             |          |
|                   |            |          |          |             |        |           | rErr vc20r  | derErr   |
|                   |            |          |          | MatCnt vc2N |        |           |             |          |
|                   |            |          | 0        |             | 0      | 0         | 0           | 0        |
| 0                 | 0          | 0        |          | 0           |        |           |             |          |
|                   |            |          |          |             |        |           |             |          |
|                   |            | r vcOHE  | CC vc1HE | ICC vc2HECC | vc3HEC | C vc0DtEr | r vc1DtErr  | vc2DtErr |
| vc3DtErr          |            |          |          |             |        |           |             |          |
| 0                 | 0          | 0        | 0        | 0           | 0      | 0         | 0 0         | 0        |
|                   |            |          |          |             |        |           |             |          |
|                   | MD_FI      | _        | DATA_FI  | _           |        | -         | _FIFO_WERR  |          |
| 0                 |            | 0        |          | 0           | 0      |           | )           |          |
|                   |            |          |          |             |        |           |             |          |
| Devno<br>CmdFifoF |            |          |          | RC EccErr   | Data   | FifoWrite | DataFif     | Read     |
|                   |            |          |          | 0           |        | 0         | 0           |          |
|                   |            | U        | 0        | U           |        | 0         | 0           |          |
| 0                 | 1<br>NC ED | DOD TATE | 0        |             |        |           |             |          |
| ALI               | ис ЕК      | KOK INF  | 0        |             |        |           |             |          |



| Devno Fl  | IFO_Fu | llErr  | Lane0Err    | Lane1Err  | Lane2Er  | r Lane | e3Err La  | ne4Err  |
|-----------|--------|--------|-------------|-----------|----------|--------|-----------|---------|
| Lane5Err  | Lane   | 6Err   | Lane7Err La | ane8Err   | Lane9Err | Lane1  | OErr Lane | 11Err   |
| Lane12Er: | r Lane | e13Err | Lane14Err 1 | Lane15Err |          |        |           |         |
| 0         |        | 0      | 0           | 0         | 0        | 0      | 0         | 0       |
| 0         | 0      | 0      | 0           | 0         | 0        | 0      | 0         | 0       |
| 0         |        |        |             |           |          |        |           |         |
|           |        |        |             |           |          |        |           |         |
| SLV       | S DEV  | ATTR-  |             |           |          |        |           |         |
| Devno     | Work   | Mode 1 | DataRate Da | taType    | WDRMode  |        | LinkId    | ImgX    |
| ImgY I    | mgW    | ImgH   | LaneRate    | ValidW    | ErrMode  |        |           |         |
| 6         | SI     | VS     | X2 RA       | W10       | None     | 0, 1,  | 2, 3      | 164 41  |
| 3840 2    | 160    | LO     | W 4144      | NONE      |          |        |           |         |
|           |        |        |             |           |          |        |           |         |
| SLV       | S LANE | INFO   |             |           |          |        |           |         |
| Devno     | Lane   | eCnt   |             | LaneID    |          |        |           |         |
|           |        |        | 0, 1,       |           |          |        |           |         |
| SLV       | S DATA | A INFO |             |           |          |        |           |         |
| Devno     | Lan    | eId    | PhyData     | AlignedDa | ata Val  | idLane |           |         |
| 0         |        | 0      | 0x38b       | 0x72      | 0,       |        |           |         |
| 0         |        | 1      | 0x2d4       | 0x2a4     | 1,       |        |           |         |
| 0         |        | 2      | 0x12d       | 0x38a     | 2,       |        |           |         |
| 0         |        | 3      | 0x23a       | 0x32a     | 3,       |        |           |         |
| 0         |        | 4      | 0x4d        | 0xe4      | 4,       |        |           |         |
| 0         |        | 5      | 0x1a3       | 0x18b     | 5,       |        |           |         |
| 0         |        | 6      | 0x109       | 0x2e4     | 6,       |        |           |         |
| 0         |        | 7      | 0x21f       | 0x1b4     | 7,       |        |           |         |
| SLV       | S DETE | ECT IN | FO          |           |          |        |           |         |
| Devno     | VC     | width  | height      |           |          |        |           |         |
| 6         | 0      | 3840   | 2160        |           |          |        |           |         |
| 6         | 1      | 0      | 0           |           |          |        |           |         |
| 6         | 2      | 0      | 0           |           |          |        |           |         |
| 6         | 3      | 0      | 0           |           |          |        |           |         |
|           |        |        |             |           |          |        |           |         |
|           |        |        | INFO        |           |          |        |           |         |
| Devno     | Heade  | erCRC  | PayloadCRC  | EccErr    | DataFif  | oWrite | DataF     | ifoRead |
| CmdFifoF  | ull    | SkewEr | r           |           |          |        |           |         |
| 6         |        | 0      | 0           | 0         | 0        |        | 0         |         |
| 0         | 1      |        |             |           |          |        |           |         |
|           |        |        |             |           |          |        |           |         |
| SLV       | S PHY  | ERROR  | INFO        |           |          |        |           |         |
| PhyIdx    | Lane   | eIdx A | AFifoAlign  | CodeErr   | DispEr   | r      |           |         |
| 0         |        | 0      | 1           | 3         | 3        |        |           |         |
| 0         |        | 1      | 1           | 3         | 3        |        |           |         |
| 0         |        | 2      | 1           | 3         | 3        |        |           |         |
|           |        |        |             |           |          |        |           |         |



| 0 | 3  | 1 | 3 | 3 |
|---|----|---|---|---|
| U | 3  | 1 | 3 | 3 |
| 0 | 4  | 0 | 3 | 3 |
| 0 | 5  | 0 | 3 | 3 |
| 0 | 6  | 0 | 3 | 3 |
| 0 | 7  | 0 | 3 | 3 |
| 1 | 8  | 0 | 0 | 0 |
| 1 | 9  | 0 | 0 | 0 |
| 1 | 10 | 0 | 0 | 0 |
| 1 | 11 | 0 | 0 | 0 |
| 1 | 12 | 0 | 0 | 0 |
| 1 | 13 | 0 | 0 | 0 |
| 1 | 14 | 0 | 0 | 0 |
| 1 | 15 | 0 | 0 | 0 |
|   |    |   |   |   |

### [Analysis]

- The MIPI RX receives differential data of the sensor by using the PHY. After detecting the sync header, the PHY controller aligns data in each lane.
- The pixel controller parses sync information and merges data in the lane into pixel data based on the bit width of raw data. It transmits pixel data to the downstream module in output mode.
- The clocks of the PHY, PHY controller, and pixel controller are provided by the pixel clock of the sensor. The clock of the output module is the associated clock, which is the same as the working clock of the downstream module. The crop function of the MIPI RX is implemented at the end of the pixel controller. Therefore, the required associated clock can be reduced after cropping.

Figure 1-3 MIPI data stream



# [Parameter Description]

| Parameter                |             | Description                               |  |  |
|--------------------------|-------------|-------------------------------------------|--|--|
| MIPI LANE<br>DIVIDE MODE | MODE        | Lane distribution mode of the MIPI RX     |  |  |
|                          | LANE DIVIDE | Detailed lane distribution of the MIPI RX |  |  |
| MIPI DEV                 | Devno       | MIPI device ID                            |  |  |



| Parameter |           | Description                                                                                                                                                 |  |  |
|-----------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| ATTR      | WorkMode  | Working mode of the MIPI device  LVDS  MIPI  CMOS  SLVS                                                                                                     |  |  |
|           | DataRate  | MIPI RX rate                                                                                                                                                |  |  |
|           | DataType  | Data type  • 8-bit raw data  • 10-bit raw data  • 12-bit raw data  • 14-bit raw data  • 16-bit raw data                                                     |  |  |
|           | WDRMode   | WDR mode  None: non-WDR mode  2To1: 2-to-1WDR  3To1: 3-to-1 WDR  4To1: 4-to-1 WDR  DOL2To1: DOL 2-to-1WDR  DOL3To1: DOL 3-to-1 WDR  DOL4To1: DOL 4-to-1 WDR |  |  |
|           | LinkId    | IDs of links used by the device A physical link corresponds to four lanes.                                                                                  |  |  |
|           | ImgX      | Horizontal coordinate of the cropped image                                                                                                                  |  |  |
|           | ImgY      | Vertical coordinate of the cropped image                                                                                                                    |  |  |
|           | ImgW      | Width of the cropped image                                                                                                                                  |  |  |
|           | ImgH      | Height of the cropped image                                                                                                                                 |  |  |
| MIPI LANE | Devno     | MIPI device ID                                                                                                                                              |  |  |
| INFO      | LaneCnt   | Number of lanes                                                                                                                                             |  |  |
|           | LaneID    | Lane ID                                                                                                                                                     |  |  |
| MIPI LINK | LinkIdx   | Link ID                                                                                                                                                     |  |  |
| INFO      | LaneCount | Number of lanes in the link                                                                                                                                 |  |  |
|           | LaneId    | Lane ID                                                                                                                                                     |  |  |
|           | PhyData0  | Real-time data 0 received by the PHY                                                                                                                        |  |  |
|           | PhyData1  | Real-time data 1 received by the PHY                                                                                                                        |  |  |





| Parameter                              |              | Description                                                                              |
|----------------------------------------|--------------|------------------------------------------------------------------------------------------|
|                                        | AlignedData0 | Real-time data 0 after the frame sync signal is detected                                 |
|                                        | AlignedData1 | Real-time data 1 after the frame sync signal is detected                                 |
|                                        | ValidLane    | Valid lane ID in the link                                                                |
|                                        |              | In MIPI mode, the value is dynamically changed. Sometimes, the value is <b>Invalid</b> . |
| MIPI DETECT                            | Devno        | MIPI RX device ID                                                                        |
| INFO (visible only in                  | VC           | Virtual channel                                                                          |
| MIPI mode)                             | width        | Total width of images detected by the MIPI controller                                    |
|                                        | height       | Total height of images detected by the MIPI controller                                   |
| LVDS DETECT                            | Devno        | MIPI RX device ID                                                                        |
| INFO                                   | VC           | Virtual channel                                                                          |
|                                        | width        | Total width of images detected by the MIPI controller                                    |
|                                        | height       | Total height of images detected by the MIPI controller                                   |
| LVDS LANE                              | Devno        | MIPI RX device ID                                                                        |
| DETECT INFO                            | Lane         | Lane ID                                                                                  |
|                                        | width        | Width detected by the lane                                                               |
|                                        | height       | Height detected by the lane                                                              |
| FSM TIMEOUT                            | phy          | PHY ID                                                                                   |
| AND ESCAPE<br>INFO<br>(visible only in | clkTOutCnt   | Timeout when the clock lane is switched from the LP to HS                                |
| MIPI mode)                             | d0TOutCnt    | Timeout when data lane 0 is switched from the LP to HS                                   |
|                                        | d1TOutCnt    | Timeout when data lane 1 is switched from the LP to HS                                   |
|                                        | d2TOutCnt    | Timeout when data lane 2 is switched from the LP to HS                                   |
|                                        | d3TOutCnt    | Timeout when data lane 3 is switched from the LP to HS                                   |
|                                        | clkEscCnt    | Timeout when the clock lane is switched to escape mode                                   |



| Parameter                    |             | Description                                                                      |  |  |
|------------------------------|-------------|----------------------------------------------------------------------------------|--|--|
|                              | d0EscCnt    | Timeout when data lane 0 is switched to escape mode                              |  |  |
|                              | d1EscCnt    | Timeout when data lane 1 is switched to escape mode                              |  |  |
|                              | d2EscCnt    | Timeout when data lane 2 is switched to escape mode                              |  |  |
|                              | d3EscCnt    | Timeout when data lane 3 is switched to escape mode                              |  |  |
| MIPI INT ERR                 | Devno       | Device ID of the MIPI RX                                                         |  |  |
| INFO (Available only in MIPI | vc0CRC      | CRC error count of the VC0 channel data                                          |  |  |
| mode)                        | vc1CRC      | CRC error count of the VC1 channel data                                          |  |  |
|                              | vc2CRC      | CRC error count of the VC2 channel data                                          |  |  |
|                              | vc3CRC      | CRC error count of the VC3 channel data                                          |  |  |
|                              | vc0OrderErr | Error count of VC0 frame sequence                                                |  |  |
|                              | vc1OrderErr | Error count of VC1 frame sequence                                                |  |  |
|                              | vc2OrderErr | Error count of VC2 frame sequence                                                |  |  |
|                              | vc3OrderErr | Error count of VC3 frame sequence                                                |  |  |
|                              | vc0NMatCnt  | Count of the short packet mismatches between the SOF and EOF of the VC 0 channel |  |  |
|                              | vc1NMatCnt  | Count of the short packet mismatches between the SOF and EOF of the VC 1 channel |  |  |
|                              | vc2NMatCnt  | Count of the short packet mismatches between the SOF and EOF of the VC 2 channel |  |  |
|                              | vc3NMatCnt  | Count of the short packet mismatches between the SOF and EOF of the VC 3 channel |  |  |
|                              | HCntErr     | EEC failure count for header errors                                              |  |  |
|                              | vc0HECC     | EEC success count for header errors of VC 0 channel                              |  |  |
|                              | ve1HECC     | EEC success count for header errors of VC 1 channel                              |  |  |
|                              | vc2HECC     | EEC success count for header errors of VC 2 channel                              |  |  |





| Parameter   |                | Description                                                   |  |  |
|-------------|----------------|---------------------------------------------------------------|--|--|
|             | ve3HECC        | EEC success count for header errors of VC 3 channel           |  |  |
|             | vc0DtErr       | Count of data types that are not supported by the VC0 channel |  |  |
|             | vc1DtErr       | Count of data types that are not supported by the VC1 channel |  |  |
|             | vc2DtErr       | Count of data types that are not supported by the VC2 channel |  |  |
|             | vc3DtErr       | Count of data types that are not supported by the VC3 channel |  |  |
|             | CMD_FIFO_RERR  | Count of raw FIFO interrupts for MIPI read commands           |  |  |
|             | DATA_FIFO_RERR | Count of raw FIFO interrupts for MIPI read data               |  |  |
|             | CMD_FIFO_WERR  | Count of raw FIFO interrupts for MIPI write commands          |  |  |
|             | DATA_FIFO_WERR | Count of raw FIFO interrupts for MIPI write data              |  |  |
| ALING ERROR | Devno          | MIPI device ID                                                |  |  |
| INFO        | FIFO_FullErr   | FIFO overflow                                                 |  |  |
|             | Lane0Err       | Lane 0 FIFO overflow                                          |  |  |
|             | Lane1Err       | Lane 1 FIFO overflow                                          |  |  |
|             | Lane2Err       | Lane 2 FIFO overflow                                          |  |  |
|             | Lane3Err       | Lane 3 FIFO overflow                                          |  |  |
|             | Lane4Err       | Lane 4 FIFO overflow                                          |  |  |
|             | Lane5Err       | Lane 5 FIFO overflow                                          |  |  |
|             | Lane6Err       | Lane 6 FIFO overflow                                          |  |  |
|             | Lane7Err       | Lane 7 FIFO overflow                                          |  |  |
|             | Lane8Err       | Lane 8 FIFO overflow                                          |  |  |
|             | Lane9Err       | Lane 9 FIFO overflow                                          |  |  |
|             | Lane10Err      | Lane 10 FIFO overflow                                         |  |  |
|             | Lane11Err      | Lane 11 FIFO overflow                                         |  |  |
|             | Lane12Err      | Lane 12 FIFO overflow                                         |  |  |
|             | Lane13Err      | Lane 13 FIFO overflow                                         |  |  |



| Parameter |           | Description                                                                                                                                                 |  |  |
|-----------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|           | Lane14Err | Lane 14 FIFO overflow                                                                                                                                       |  |  |
|           | Lane15Err | Lane 15 FIFO overflow                                                                                                                                       |  |  |
| SLVS DEV  | Devno     | SLVS device number                                                                                                                                          |  |  |
| ATTR      | WorkMode  | SLVS device working mode  LVDS  MIPI  CMOS  SLVS                                                                                                            |  |  |
|           | DataRate  | SLVS data rate                                                                                                                                              |  |  |
|           | DataType  | Data type  • 8-bit raw data  • 10-bit raw data  • 12-bit raw data  • 14-bit raw data  • 16-bit raw                                                          |  |  |
|           | WDRMode   | WDR mode  None: non-WDR mode  2To1: 2-to-1WDR  3To1: 3-to-1 WDR  4To1: 4-to-1 WDR  DOL2To1: DOL 2-to-1WDR  DOL3To1: DOL 3-to-1 WDR  DOL4To1: DOL 4-to-1 WDR |  |  |
|           | LinkId    | IDs of links used by the device. A physical link corresponds to four lanes.                                                                                 |  |  |
|           | ImgX      | Horizontal coordinate of the cropped image                                                                                                                  |  |  |
|           | ImgY      | Vertical coordinate of the cropped image                                                                                                                    |  |  |
|           | ImgW      | Width of the cropped image                                                                                                                                  |  |  |
|           | ImgH      | Height of the cropped image                                                                                                                                 |  |  |
|           | LaneRate  | Lane rate                                                                                                                                                   |  |  |
|           | ValidW    | Actual valid width of the sensor                                                                                                                            |  |  |
|           | ErrMode   | SLVS CRC/ECC mode                                                                                                                                           |  |  |
| SLVS LANE | Devno     | SLVS device number                                                                                                                                          |  |  |
| INFO      | LaneCnt   | Number of lanes                                                                                                                                             |  |  |
|           | LaneID    | Lane ID                                                                                                                                                     |  |  |



| Parameter   |               | Description                                                                                                       |
|-------------|---------------|-------------------------------------------------------------------------------------------------------------------|
| SLVS DATA   | Devno         | SLVS device ID                                                                                                    |
| INFO        | LaneID        | Lane ID                                                                                                           |
|             | PhyData       | Real-time data received by the lane corresponding to the PHY                                                      |
|             | AlignedData   | Real-time data received by the lane corresponding to the PHY after the synchronization code is detected           |
|             | ValidLane     | Valid lane ID in the PHY In LVDS mode, the value is dynamically changed. Sometimes, the value is <b>Invalid</b> . |
| SLVS DETECT | Devno         | SLVS device number                                                                                                |
| INFO        | VC            | Virtual Channel                                                                                                   |
|             | width         | Total width of images detected by the SLVS controller                                                             |
|             | height        | Total height of images detected by the SLVS controller                                                            |
| SLVS DEV    | Devno         | SLVS device number                                                                                                |
| ERROR INFO  | HeaderCRC     | Number of data header CRC errors                                                                                  |
|             | PayloadCRC    | Number of data CRC errors                                                                                         |
|             | EccErr        | Number of ECC errors                                                                                              |
|             | DataFifoWrite | Number of data FIFO write errors                                                                                  |
|             | DataFifoRead  | Number of data FIFO read errors                                                                                   |
|             | CmdFifoFull   | Counts of command FIFO full                                                                                       |
|             | SkewErr       | Number of skew errors                                                                                             |
| SLVS PHY    | PhyIdx        | PHY ID                                                                                                            |
| ERROR INFO  | LaneIdx       | Lane ID                                                                                                           |
|             | AFifoAlign    | Number of FIFO alignment errors                                                                                   |
|             | CodeErr       | Number of 10B8B coding errors                                                                                     |
|             | DispErr       | Number of disparity errors                                                                                        |

# Hi3519A V100

# [Debugging Information]

Module: [MIPI\_RX], Build Time[Jul 30 2018, 10:02:04]

| MIPI       | LANE DIVIDE MOI  | )E              |           |          |           |        |
|------------|------------------|-----------------|-----------|----------|-----------|--------|
| MODE       | LANE DIVIDE      |                 |           |          |           |        |
| 5          | 4+4+2+2          |                 |           |          |           |        |
| MIPI       | DEV ATTR         |                 |           |          |           |        |
| Devno V    | WorkMode DataRa  | ite DataType    | WDRMode   | ImgX     | ImgY      | ImgW   |
| ImgH       |                  |                 |           |          |           |        |
| 0          | MIPI X1          | RAW12           | None      | 0        | 0 384     | 0 2160 |
| MTPT       | LANE INFO        |                 |           |          |           |        |
| Devno      | La               |                 |           |          |           |        |
|            | 0, 1, 2,         |                 | -1        |          |           |        |
|            | -, -, -,         | · -, -, -, -,   | _         |          |           |        |
| MIPI       | PHY DATA INFO-   |                 |           |          |           |        |
| PhyId      | LaneId           | PhyData         |           | MipiD    | ata       |        |
| LvdsData   |                  |                 |           |          |           |        |
| 0          | 0, 1, 2, 3       | 0x00,0x00,0xf   | f,0xff    | 0xb5,0x9 | of,0x40,0 | x13    |
| 0xcc,0x88, | 0x38,0x43        |                 |           |          |           |        |
| 1          | 4, 5, 6, 7       | 0x00,0x00,0x0   | 0,0x00    | 0x00,0x0 | 0,0x00,0  | x00    |
| 0x00,0x00, | 0x00,0x00        |                 |           |          |           |        |
| 2          | 8, 9,10,11       | 0x00,0x00,0x0   | 0,0x00    | 0x00,0x0 | 0,0x00,0  | x00    |
| 0x00,0x00, | 0x00,0x00        |                 |           |          |           |        |
|            |                  |                 |           |          |           |        |
| MIPI       | DETECT INFO      |                 |           |          |           |        |
| Devno VC   | width height     |                 |           |          |           |        |
|            | 3840 2160        |                 |           |          |           |        |
|            | 0 0              |                 |           |          |           |        |
|            | 0 0              |                 |           |          |           |        |
| 0 3        |                  |                 |           |          |           |        |
|            | DETECT INFO      |                 |           |          |           |        |
|            | width height     |                 |           |          |           |        |
|            | 3840 2160<br>0 0 |                 |           |          |           |        |
|            | 0 0              |                 |           |          |           |        |
|            | 0 0              |                 |           |          |           |        |
| 0 3        | O O              |                 |           |          |           |        |
| LVDS       | LANE DETECT IN   | FO              |           |          |           |        |
|            | ne width heig    |                 |           |          |           |        |
|            | 2 960 2179       |                 |           |          |           |        |
| 0          | 4 960 2179       |                 |           |          |           |        |
| 0 5        | 5 960 2179       | )               |           |          |           |        |
| 0          | 7 960 2179       | )               |           |          |           |        |
| РНҮ С      | CIL ERR INT INFO | )               |           |          |           |        |
| PhyId (    | Clk2TmOut ClkTm  | nOut LaneOTmOut | Lane1Tm   | Out Lane | e2TmOut   |        |
| Lane3TmOut | Clk2Esc ClkE     | sc LaneOEsc La  | ane1Esc I | Lane2Esc | Lane3Esc  |        |
|            |                  |                 |           |          |           |        |



|      | 0       |        | 0       | 0         | 0        | 0        | 0           | 0           | C     |
|------|---------|--------|---------|-----------|----------|----------|-------------|-------------|-------|
| 0    | 0       |        | 0       | 0         | 0        |          |             |             |       |
|      | 1       |        | 0       | 0         | 0        | 0        | 0           | 0           | 0     |
| 0    | 0       |        | 0       | 0         | 0        |          |             |             |       |
|      | 2       |        | 0       | 0         | 0        | 0        | 0           | 0           | 0     |
| 0    | 0       |        | 0       | 0         | 0        |          |             |             |       |
|      | -MIPI   | ERROR  | . INT I | NFO 1     |          |          |             |             |       |
| De   | evno 1  | Ecc2   | Vc0CRC  | Vc1CRC    | Vc2CRC   | Vc3CRC   | Vc0EccCorr  | ct Vc1EccC  | orrct |
| Vc2E | ccCor   | rct V  | c3EccC  | orrct     |          |          |             |             |       |
|      | 0       | 0      | 0       | 0         | 0        | 0        | 0           | 0           |       |
| 0    |         | 0      |         |           |          |          |             |             |       |
|      |         |        |         |           |          |          |             |             |       |
|      | -MIPI   | ERROR  | INT I   | NFO 2     |          |          |             |             |       |
| De   | evno '  | Vc0Dt  | Vc1Dt   | Vc2Dt '   | Vc3Dt V  | c0FrmCrc | Vc1FrmCrc   | Vc2FrmCrc   |       |
| Vc3F | 'rmCrc  |        |         |           |          |          |             |             |       |
|      | 0       | 0      | 0       | 0         | 0        | 0        | 0           | 0           | 0     |
|      |         |        |         |           |          |          |             |             |       |
|      | -MIPI   | ERROR  | INT I   | NFO 3     |          |          |             |             |       |
| De   | evno '  | Vc0Frm | Seq V   | c1FrmSeq  | Vc2Frm:  | Seq Vc3F | rmSeq Vc0B  | ndryMt      |       |
| Vc1B | BndryMt | vc2    | BndryMt | t Vc3Bnd  | ryMt     |          |             |             |       |
|      | 0       |        | 0       | 0         | 0        | 0        | 0           | 0           |       |
| 0    |         | 0      |         |           |          |          |             |             |       |
|      |         |        |         |           |          |          |             |             |       |
|      | -MIPI   | ERROR  | INT I   | NFO 4     |          |          |             |             |       |
| De   | evno :  | DataFi | foRdEr  | r CmdFif  | FoRdErr  | Vsync C  | mdFifoWrErr | DataFifo    | WrErr |
|      | 0       |        | 0       |           | 0 (      |          | 0           | 0           |       |
|      | -LVDS   | ERROR  | INT I   | NFO 1     |          |          |             |             |       |
| De   | evno '  | Vsync  | CmdRd   | Err CmdW  | rErr Po  | pErr St  | atErr       |             |       |
|      | 0       | 0      | C       | ) (       | 0        | 0        |             |             |       |
|      |         |        |         |           |          |          |             |             |       |
|      |         |        |         |           |          |          |             |             |       |
| De   | evno :  | Link0W | IrErr : | Link1WrEı | r Link   | 2WrErr I | ink0RdErr   | Link1RdErr  |       |
| Link | 2RdEr   | r      |         |           |          |          |             |             |       |
|      | 0       |        | 0       | 0         | (        | )        | 0           | 0           | 0     |
|      |         |        |         |           |          |          |             |             |       |
|      | -LVDS   | ERROR  | INT I   | NFO 3     |          |          |             |             |       |
| De   | evno :  | Lane0E | err La  | ne1Err L  | ane2Err  | Lane3Er  | r Lane4Err  | Lane5Err    |       |
| Lane | 6Err    | Lane7  | Err La  | ne8Err 1  | Lane9Err | Lane10E  | rr Lanel1Er | r           |       |
|      | 0       | (      | )       | 0         | 0        | 0        | 0           | 0 0         |       |
|      |         |        |         | 0         |          |          |             |             |       |
|      | -ALIG   | N ERRO | R INT   | INFO      |          |          |             |             |       |
| De   | evno :  | FIFO_F | ullErr  | Lane0E1   | r Lane   | lErr Lar | e2Err Lane  | 3Err Lane4  | Err   |
| Lane | 5Err    | Lane6  | Err La  | ne7Err 1  | Lane8Err | Lane9E   | rr Lane10Er | r LanellErr | î     |
|      | 0       |        | 0       | 0         | 0        | 0        | 0           | 0           | 0     |



|       |         |               |                | 0         |         |      |       |         |
|-------|---------|---------------|----------------|-----------|---------|------|-------|---------|
|       |         |               |                | DataType  |         |      |       | Ттам    |
|       |         | te Val        |                | расатуре  | WDIMOGE | Imgz | Imgi  | Imgw    |
| -     |         |               |                | RAW12     | None    | 48   | 24 38 | 40 2160 |
| IGHT  |         |               |                |           |         |      |       |         |
|       |         |               |                |           |         |      |       |         |
| SL    | VS LA   | NE INFO       |                |           |         |      |       |         |
| Devno | )       |               | LaneID         |           |         |      |       |         |
| 0     |         | 6, 4          | , 5, 0,        | 7, 2, -1, | -1      |      |       |         |
| SL    | VS PH   | Y DATA        | INFO           |           |         |      |       |         |
| Phylo | l L     | aneID         | PhyData        | AlignedD  | ata     |      |       |         |
| 0     |         | 0             | 0x227          | 0x345     | 5       |      |       |         |
| 0     |         | 1             | 0x0            | 0x0       |         |      |       |         |
| 0     |         | 2             | 0x30d          | 0x1c6     | 5       |      |       |         |
| 0     |         | 3             | 0x0            | 0x0       |         |      |       |         |
| 0     |         | 4             | 0x2b4          | 0x3a9     | )       |      |       |         |
| 0     |         | 5             | 0x368          | 0x18b     |         |      |       |         |
| 0     |         | 6             | 0x25c          | 0x274     | 1       |      |       |         |
| 0     |         | 7             | 0x1c4          | 0x134     | l       |      |       |         |
| Devno | VC<br>0 | width<br>3840 | height<br>2160 |           |         |      |       |         |
| 0     | 1       | 0             | 0              |           |         |      |       |         |
| 0     |         | 0             |                |           |         |      |       |         |
| 0     | 3       | 0             | 0              |           |         |      |       |         |
| SL    | VS DE   | V ERROR       | INFO           |           |         |      |       |         |
|       |         |               |                | .C EccErr |         |      |       | foRead  |
|       |         | SkewEr        |                |           |         |      |       |         |
| 0     |         | 0             | 0              | 0         | 0       |      | 0     |         |
|       | 0       |               |                |           |         |      |       |         |
|       |         |               |                |           |         |      |       |         |
|       |         |               |                |           |         |      |       |         |
| _     | K La    |               | _              | CodeErr   | _       | r    |       |         |
| 0     |         | 0             | -              | 0         | 0       |      |       |         |
| 0     |         | 1             | 0              | 0         | 0       |      |       |         |
| 0     |         | 2             | 0              |           | 0       |      |       |         |
| 0     |         | 3             | 0              | 0         | 0       |      |       |         |
| 0     |         | 4             | 0              | 0         | 0       |      |       |         |
| 0     |         | 5             | 0              | 0         | 0       |      |       |         |
| 0     |         | 6             | 0              | 0         | 0       |      |       |         |



0 7 0 0 0

### [Analysis]

- The MIPI RX receives differential data of the sensor by using the PHY. After detecting the sync header, the PHY controller aligns data in each lane.
- The pixel controller parses sync information and merges data in the lane into pixel data based on the bit width of raw data. It transmits pixel data to the downstream module in output mode.
- The clocks of the PHY, PHY controller, and pixel controller are provided by the pixel clock of the sensor. The clock of the output module is the associated clock, which is the same as the working clock of the downstream module. The crop function of the MIPI RX is implemented at the end of the pixel controller. Therefore, the required associated clock can be reduced after cropping.

Figure 1-4 MIPI data stream



### [Parameter Description]

| Parameter                      |             | Description                                                     |
|--------------------------------|-------------|-----------------------------------------------------------------|
| MIPI<br>LANE<br>DIVIDE<br>MODE | MODE        | Lane distribution mode of the MIPI RX                           |
|                                | LANE DIVIDE | Detailed lane distribution of the MIPI RX                       |
| -                              | Devno       | MIPI device ID                                                  |
| ATTR                           | WorkMode    | Working mode of the MIPI device  • LVDS  • MIPI  • CMOS  • SLVS |
|                                | DataRate    | MIPI RX rate                                                    |





| Parameter          |          | Description                                                                                                                                                 |  |  |  |  |
|--------------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|                    | DataType | Data type  • 8-bit raw data  • 10-bit raw data  • 12-bit raw data  • 14-bit raw data  • 16-bit raw data                                                     |  |  |  |  |
|                    | WDRMode  | WDR mode  None: non-WDR mode  2To1: 2-to-1WDR  3To1: 3-to-1 WDR  4To1: 4-to-1 WDR  DOL2To1: DOL 2-to-1WDR  DOL3To1: DOL 3-to-1 WDR  DOL4To1: DOL 4-to-1 WDR |  |  |  |  |
|                    | ImgX     | Horizontal coordinate of the cropped image                                                                                                                  |  |  |  |  |
|                    | ImgY     | Vertical coordinate of the cropped image                                                                                                                    |  |  |  |  |
|                    | ImgW     | Width of the cropped image                                                                                                                                  |  |  |  |  |
|                    | ImgH     | Height of the cropped image                                                                                                                                 |  |  |  |  |
| MIPI               | Devno    | MIPI device ID                                                                                                                                              |  |  |  |  |
| LANE<br>INFO       | LaneCnt  | Number of lanes                                                                                                                                             |  |  |  |  |
|                    | LaneID   | Lane ID                                                                                                                                                     |  |  |  |  |
| MIPI PHY           | PhyId    | PHY ID                                                                                                                                                      |  |  |  |  |
| DATA<br>INFO       | LaneId   | Lane ID                                                                                                                                                     |  |  |  |  |
|                    | PhyData  | Real-time data received by the four lanes corresponding to the PHY                                                                                          |  |  |  |  |
|                    | MipiData | Real-time data received after the four lanes corresponding to the PHY detect the MIPI frame synchronization signal                                          |  |  |  |  |
|                    | LvdsData | Real-time data received after the four lanes corresponding to the PHY detect the LVDS frame synchronization signal                                          |  |  |  |  |
| MIPI               | Devno    | MIPI RX device ID                                                                                                                                           |  |  |  |  |
| DETECT<br>INFO     | VC       | Virtual channel                                                                                                                                             |  |  |  |  |
| (available only in | width    | Total width of images detected by the MIPI controller                                                                                                       |  |  |  |  |





| Parameter                |            | Description                                                          |
|--------------------------|------------|----------------------------------------------------------------------|
| MIPI mode)               | height     | Total height of images detected by the MIPI controller               |
| LVDS                     | Devno      | MIPI RX device ID                                                    |
| DETECT<br>INFO           | VC         | Virtual channel                                                      |
| (available only in LVDS  | width      | Total width of images detected by the MIPI controller                |
| mode)                    | height     | Total height of images detected by the MIPI controller               |
| LVDS                     | Devno      | MIPI RX device ID                                                    |
| LANE<br>DETECT           | Lane       | Lane ID                                                              |
| INFO (available          | width      | Image width detected on the lane                                     |
| only in<br>LVDS<br>mode) | height     | Image height detected on the lane                                    |
| PHY CIL                  | phy        | PHY ID                                                               |
| ERR INT<br>INFO          | Clk2TmOut  | Timeout when the lane of clock 2 is switched from LP mode to HS mode |
|                          | ClkTmOut   | Timeout when the lane of clock 1 is switched from LP mode to HS mode |
|                          | Lane0TmOut | Timeout when data lane 0 is switched from LP mode to HS mode         |
|                          | Lane1TmOut | Timeout when data lane 1 is switched from LP mode to HS mode         |
|                          | Lane2TmOut | Timeout when data lane 2 is switched from LP mode to HS mode         |
|                          | Lane3TmOut | Timeout when data lane 3 is switched from LP mode to HS mode         |
|                          | Clk2Esc    | Timeout when the lane of clock 2 is switched to escape mode          |
|                          | ClkEsc     | Timeout when the lane of clock 1 is switched to escape mode          |
|                          | Lane0Esc   | Timeout when data lane 0 is switched to escape mode                  |
|                          | Lane1Esc   | Timeout when data lane 1 is switched to escape mode                  |
|                          | Lane2Esc   | Timeout when data lane 2 is switched to escape mode                  |





| Parameter                         |              | Description                                                  |  |  |  |
|-----------------------------------|--------------|--------------------------------------------------------------|--|--|--|
|                                   | Lane3Esc     | Timeout when data lane 3 is switched to escape mode          |  |  |  |
| MIPI                              | Devno        | MIPI RX device ID                                            |  |  |  |
| ERROR<br>INT INFO 1<br>(available | Ecc2         | Whether the header has at least two uncorrectable ECC errors |  |  |  |
| only in MIPI mode)                | Vc0CRC       | Count of CRC errors for VC0 data                             |  |  |  |
|                                   | Vc1CRC       | Count of CRC errors for VC1 data                             |  |  |  |
|                                   | Vc2CRC       | Count of CRC errors for VC2 data                             |  |  |  |
|                                   | Vc3CRC       | Count of CRC errors for VC3 data                             |  |  |  |
|                                   | Vc0EccCorrct | Count of the corrected ECC errors for the VC0 header         |  |  |  |
|                                   | Vc1EccCorret | Count of the corrected ECC errors for the VC1 header         |  |  |  |
|                                   | Vc2EccCorrct | Count of the corrected ECC errors for the VC2 header         |  |  |  |
|                                   | Vc3EccCorret | Count of the corrected ECC errors for the VC3 header         |  |  |  |
| MIPI                              | Devno        | MIPI RX device ID                                            |  |  |  |
| ERROR<br>INT INFO 2               | Vc0Dt        | Count of data types unsupported by VC0                       |  |  |  |
| (available only in                | Vc1Dt        | Count of data types unsupported by VC1                       |  |  |  |
| MIPI mode)                        | Vc2Dt        | Count of data types unsupported by VC2                       |  |  |  |
|                                   | Vc3Dt        | Count of data types unsupported by VC3                       |  |  |  |
|                                   | Vc0FrmCrc    | Count of frame data errors for VC0                           |  |  |  |
|                                   | Vc1FrmCrc    | Count of frame data errors for VC1                           |  |  |  |
|                                   | Vc2FrmCrc    | Count of frame data errors for VC2                           |  |  |  |
|                                   | Vc3FrmCrc    | Count of frame data errors for VC3                           |  |  |  |
| MIPI                              | Devno        | MIPI RX device ID                                            |  |  |  |
| ERROR<br>INT INFO 3               | Vc0FrmSeq    | Count of frame sequence errors for VC0                       |  |  |  |
| (available only in                | Vc1FrmSeq    | Count of frame sequence errors for VC1                       |  |  |  |
| MIPI mode)                        | Vc2FrmSeq    | Count of frame sequence errors for VC2                       |  |  |  |
|                                   | Vc3FrmSeq    | Count of frame sequence errors for VC3                       |  |  |  |
|                                   | Vc0BndryMt   | Count of short packets with SOF and EOF mismatching for VC0  |  |  |  |





| Parameter                     |               | Description                                                 |  |  |  |
|-------------------------------|---------------|-------------------------------------------------------------|--|--|--|
|                               | Vc1BndryMt    | Count of short packets with SOF and EOF mismatching for VC1 |  |  |  |
|                               | Vc2BndryMt    | Count of short packets with SOF and EOF mismatching for VC2 |  |  |  |
|                               | Vc3BndryMt    | Count of short packets with SOF and EOF mismatching for VC3 |  |  |  |
| MIPI                          | Devno         | MIPI RX device ID                                           |  |  |  |
| ERROR<br>INT INFO 4           | DataFifoRdErr | Count of MIPI CTRL read data FIFO interrupts                |  |  |  |
| (available only in MIPI mode) | CmdFifoRdErr  | Count of MIPI CTRL read command FIFO interrupts             |  |  |  |
|                               | Vsync         | Count of MIPI CTR VSync interrupts                          |  |  |  |
|                               | CmdFifoWrErr  | Count of MIPI CTRL write command FIFO interrupts            |  |  |  |
|                               | DataFifoWrErr | Count of MIPI CTRL write data FIFO interrupts               |  |  |  |
| LVDS                          | Devno         | MIPI device ID                                              |  |  |  |
| ERROR<br>INT INFO 1           | Vsync         | Count of VSync interrupts for LVDS                          |  |  |  |
| (available only in LVDS       | CmdRdErr      | Count of CMD_FIFO read error interrupts for LVDS            |  |  |  |
| mode)                         | CmdWrErr      | Count of CMD_FIFO write error interrupts for LVDS           |  |  |  |
|                               | PopErr        | Count of line_buf read error interrupts for LVDS            |  |  |  |
|                               | StatErr       | Count of lane synchronization error interrupts for LVDS     |  |  |  |
| LVDS                          | Devno         | MIPI device ID                                              |  |  |  |
| ERROR<br>INT INFO 2           | Link0WrErr    | Count of FIFO read error interrupts for link 0              |  |  |  |
| (available only in            | Link1WrErr    | Count of FIFO read error interrupts for link 1              |  |  |  |
| LVDS<br>mode)                 | Link2WrErr    | Count of FIFO read error interrupts for link 2              |  |  |  |
| mode)                         | Link0RdErr    | Count of FIFO write error interrupts for link 0             |  |  |  |
|                               | Link1RdErr    | Count of FIFO write error interrupts for link 1             |  |  |  |
|                               | Link2RdErr    | Count of FIFO write error interrupts for link 2             |  |  |  |
| LVDS                          | Devno         | MIPI device ID                                              |  |  |  |
| ERROR<br>INT INFO 3           | Lane0Err      | Count of synchronization error interrupts for lane 0        |  |  |  |
| (available only in            | Lane1Err      | Count of synchronization error interrupts for lane 1        |  |  |  |
| LVDS                          | Lane2Err      | Count of synchronization error interrupts for lane 2        |  |  |  |





| Parameter     |              | Description                                                                     |  |  |  |
|---------------|--------------|---------------------------------------------------------------------------------|--|--|--|
| mode)         | Lane3Err     | Count of synchronization error interrupts for lane 3                            |  |  |  |
|               | Lane4Err     | Count of synchronization error interrupts for lane 4                            |  |  |  |
|               | Lane5Err     | Count of synchronization error interrupts for lane 5                            |  |  |  |
|               | Lane6Err     | Count of synchronization error interrupts for lane 6                            |  |  |  |
|               | Lane7Err     | Count of synchronization error interrupts for lane 7                            |  |  |  |
|               | Lane8Err     | Count of synchronization error interrupts for lane 8                            |  |  |  |
|               | Lane9Err     | Count of synchronization error interrupts for lane 9                            |  |  |  |
|               | Lane10Err    | Count of synchronization error interrupts for lane 10                           |  |  |  |
|               | Lane11Err    | Count of synchronization error interrupts for lane 11                           |  |  |  |
| ALING         | Devno        | MIPI device ID                                                                  |  |  |  |
| ERROR<br>INFO | FIFO_FullErr | FIFO overflow                                                                   |  |  |  |
|               | Lane0Err     | Lane 0 FIFO overflow                                                            |  |  |  |
|               | Lane1Err     | Lane 1 FIFO overflow                                                            |  |  |  |
|               | Lane2Err     | Lane 2 FIFO overflow                                                            |  |  |  |
|               | Lane3Err     | Lane 3 FIFO overflow                                                            |  |  |  |
|               | Lane4Err     | Lane 4 FIFO overflow                                                            |  |  |  |
|               | Lane5Err     | Lane 5 FIFO overflow                                                            |  |  |  |
|               | Lane6Err     | Lane 6 FIFO overflow                                                            |  |  |  |
|               | Lane7Err     | Lane 7 FIFO overflow                                                            |  |  |  |
|               | Lane8Err     | Lane 8 FIFO overflow                                                            |  |  |  |
|               | Lane9Err     | Lane 9 FIFO overflow                                                            |  |  |  |
|               | Lane10Err    | Lane 10 FIFO overflow                                                           |  |  |  |
|               | Lane11Err    | Lane 11 FIFO overflow                                                           |  |  |  |
| SLVS DEV      | Devno        | SLVS device ID                                                                  |  |  |  |
| ATTR          | WorkMode     | Working mode of the SLVS device, such as LVDS, MIPI, CMOS, or SLVS              |  |  |  |
|               | DataRate     | SLVS data rate                                                                  |  |  |  |
|               | DataType     | Data type, which can be RAW8 bit, RAW10 bit, RAW12 bit, RAW14 bit, or RAW16 bit |  |  |  |





| Parameter      |             | Description                                                                                                                                                   |  |  |  |
|----------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|                | WDRMode     | WDR mode  None: non-WDR mode  2To1: 2-to-1 WDR  3To1: 3-to-1 WDR  4To1: 4-to-1 WDR  DOL2To1: DOL 2-to-1 WDR  DOL3To1: DOL 3-to-1 WDR  DOL4To1: DOL 4-to-1 WDR |  |  |  |
|                | ImgX        | X coordinate of the start position of the cropped image                                                                                                       |  |  |  |
|                | ImgY        | Y coordinate of the start position of the cropped image                                                                                                       |  |  |  |
|                | ImgW        | Width of the cropped image                                                                                                                                    |  |  |  |
|                | ImgH        | Height of the cropped image                                                                                                                                   |  |  |  |
|                | LaneRate    | Lane rate                                                                                                                                                     |  |  |  |
|                | ValidW      | Actual valid width of the sensor                                                                                                                              |  |  |  |
| SLVS<br>LANE   | Devno       | SLVS device ID                                                                                                                                                |  |  |  |
| INFO           | LaneCnt     | Number of lanes                                                                                                                                               |  |  |  |
|                | LaneID      | Lane ID                                                                                                                                                       |  |  |  |
| SLVS PHY       | PhyId       | PHY ID                                                                                                                                                        |  |  |  |
| DATA<br>INFO   | LaneID      | Lane ID                                                                                                                                                       |  |  |  |
|                | PhyData     | Real-time data received by the lane corresponding to the PHY                                                                                                  |  |  |  |
|                | AlignedData | Real-time data received after the lane corresponding to the PHY detects the synchronization code                                                              |  |  |  |
| SLVS           | Devno       | SLVS device ID                                                                                                                                                |  |  |  |
| DETECT<br>INFO | VC          | Virtual channel                                                                                                                                               |  |  |  |
|                | width       | Total width of images detected by the SLVS controller                                                                                                         |  |  |  |
|                | height      | Total height of images detected by the SLVS controller                                                                                                        |  |  |  |
| SLVS DEV       | Devno       | SLVS device ID                                                                                                                                                |  |  |  |
| ERROR<br>INFO  | HeaderCRC   | Count of data header CRC errors                                                                                                                               |  |  |  |
|                | PayloadCRC  | Count of data CRC errors                                                                                                                                      |  |  |  |
|                | EccErr      | Count of ECC errors                                                                                                                                           |  |  |  |



| Parameter     |               | Description                                  |  |
|---------------|---------------|----------------------------------------------|--|
|               | DataFifoWrite | Count of data FIFO write errors              |  |
|               | DataFifoRead  | Count of data FIFO read errors               |  |
|               | CmdFifoFull   | Count of the full status of the command FIFO |  |
|               | SkewErr       | Count of skew errors                         |  |
| SLVS PHY      | PhyIdx        | PHY ID                                       |  |
| ERROR<br>INFO | LaneIdx       | Lane ID                                      |  |
|               | AFifoAlign    | Count of FIFO alignment errors               |  |
|               | CodeErr       | Count of 10B8B encoding errors               |  |
|               | DispErr       | Count of disparity errors                    |  |

### Hi3516C V500

#### [Debugging Information]

```
Module: [MIPI RX], Build Time[Oct 8 2018, 09:27:31]
----MIPI LANE DIVIDE MODE-----
MODE LANE DIVIDE
  0
----MIPI DEV ATTR-----
 Devno WorkMode DataRate DataType WDRMode ImgX ImgY
ImgW ImgH
  0 MIPI X1 RAW12 None 0 204 2592
1944
----MIPI LANE INFO-----
         LaneID
 Devno
   0 0, 1, 2, 3
----MIPI PHY DATA INFO-----
     LaneId
 PhyId
                   PhyData
                                MipiData
LvdsData
   0 0, 1, 2, 3 0x00,0x00,0x00,0x49 0x36,0x2b,0x34,0x45
0x9b, 0x1ad275, 0x00, 0x00
----MIPI DETECT INFO-----
Devno VC width height
  0 0 2592 1760
           0
  0 1 0
  0 2
        0
            0
```

| 0 3       |            |            |           |            |                |             |    |
|-----------|------------|------------|-----------|------------|----------------|-------------|----|
|           | DETECT IN  |            |           |            |                |             |    |
|           | width h    | _          |           |            |                |             |    |
|           | 2592       |            |           |            |                |             |    |
|           | 0          |            |           |            |                |             |    |
| 0 2       | 0          | 0          |           |            |                |             |    |
| 0 3       | 0          | 0          |           |            |                |             |    |
|           | LANE DETE  |            |           |            |                |             |    |
|           | ne width   | _          |           |            |                |             |    |
|           | 0 648      |            |           |            |                |             |    |
|           | 1 648      |            |           |            |                |             |    |
|           | 2 648      |            |           |            |                |             |    |
|           | 3 648      |            |           |            |                |             |    |
|           | CIL ERR IN |            |           |            |                |             | -  |
| PhyId     | Clk2TmOut  | ClkTmOut   | Lane0TmO  | ut Lane1   | CmOut Lane2    | ?TmOut      |    |
|           |            |            |           |            | Lane2Esc I     | Lane3Esc    |    |
| 0         | 0          | 0          | 0         | 0          | 0              | 0           | 0  |
| 0         | 0          | 0          | 0         |            |                |             |    |
| MIPI      | ERROR INT  | INFO 1     |           |            |                |             |    |
|           |            |            | Jc2CRC Vc | 3CRC Vc0E  | CccCorrct V    | c1EccCorrct |    |
|           | rct Vc3Ec  |            |           |            |                |             |    |
| 0         | 0 0        | 0          | 0         | 0          | 0              | 0           |    |
| 0         | 0          |            |           |            |                |             |    |
|           |            |            |           |            |                |             |    |
|           |            |            |           |            |                |             |    |
|           |            | Dt Vc2Dt   | Vc3Dt Vc  | OFrmCrc    | Vc1FrmCrc '    | Vc2FrmCrc   |    |
| Vc3FrmCrc |            |            |           |            |                |             |    |
| 0         | 0 0        | 0          | 0         | 0          | 0              | 0 0         |    |
|           |            |            |           |            |                |             |    |
|           |            |            |           |            |                |             |    |
|           |            |            |           | eq Vc3F'rr | nSeq Vc0Bno    | dryMt       |    |
|           | t Vc2Bndr  |            |           |            |                |             |    |
| 0         |            | 0          | 0         | 0          | 0              | 0           |    |
| 0         | 0          |            |           |            |                |             |    |
| \/T.D.T   |            |            |           |            |                |             |    |
|           |            |            |           |            |                |             |    |
|           |            |            |           |            | Err DataFi     | IOWTETT     |    |
| 0         |            | 0          | 0         | 0          | 0              |             |    |
|           |            |            |           |            | T do la OMARIA |             |    |
|           |            |            | _         |            |                | rr LinkORdE | rr |
| 0         | 0          | 0          | 0 0       |            | 0 0            | J           |    |
|           |            |            |           |            |                |             |    |
| 3.7.= 0   | M EDDOD -  | III. TAIDO |           |            |                |             |    |
| ALIG      |            |            |           |            | Lane2Err       |             |    |



0 0 0 0 0

### [Analysis]

- The MIPI RX receives differential data of the sensor by using the PHY. After detecting the sync header, the PHY controller aligns data in each lane.
- The pixel controller parses sync information and merges data in the lane into pixel data based on the bit width of raw data. It transmits pixel data to the downstream module in output mode.
- The PHY, PHY controller, and pixel controller use the pixel clock of the sensor. The clock of the output module is the associated clock, which is the same as the working clock of the downstream module. The crop function of the MIPI RX is implemented at the end of the pixel controller. Therefore, the required associated clock can be reduced after cropping.

Figure 1-5 MIPI data stream



### [Parameter Description]

| Parameter                      |             | Description                                       |  |  |
|--------------------------------|-------------|---------------------------------------------------|--|--|
| MIPI<br>LANE<br>DIVIDE<br>MODE | MODE        | Lane distribution mode of the MIPI RX             |  |  |
|                                | LANE DIVIDE | Detailed lane distribution of the MIPI RX         |  |  |
| MIPI DEV                       | Devno       | MIPI device ID                                    |  |  |
| ATTR                           | WorkMode    | Working mode of the MIPI device  LVDS  MIPI  CMOS |  |  |
|                                | DataRate    | MIPI RX rate                                      |  |  |





| Parameter                     |          | Description                                                                                                                                                 |  |  |  |
|-------------------------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|                               | DataType | Data type  • 8-bit raw data  • 10-bit raw data  • 12-bit raw data  • 14-bit raw data  • 16-bit raw data                                                     |  |  |  |
|                               | WDRMode  | WDR mode  None: non-WDR mode  2To1: 2-to-1WDR  3To1: 3-to-1 WDR  4To1: 4-to-1 WDR  DOL2To1: DOL 2-to-1WDR  DOL3To1: DOL 3-to-1 WDR  DOL4To1: DOL 4-to-1 WDR |  |  |  |
|                               | ImgX     | Horizontal coordinate of the cropped image                                                                                                                  |  |  |  |
|                               | ImgY     | Vertical coordinate of the cropped image                                                                                                                    |  |  |  |
|                               | ImgW     | Width of the cropped image                                                                                                                                  |  |  |  |
|                               | ImgH     | Height of the cropped image                                                                                                                                 |  |  |  |
| MIPI                          | Devno    | MIPI device ID                                                                                                                                              |  |  |  |
| LANE<br>INFO                  | LaneID   | Lane ID                                                                                                                                                     |  |  |  |
| MIPI PHY                      | PhyId    | PHY ID                                                                                                                                                      |  |  |  |
| DATA<br>INFO                  | LaneId   | Lane ID                                                                                                                                                     |  |  |  |
|                               | PhyData  | Real-time data received by the four lanes corresponding to the PHY                                                                                          |  |  |  |
|                               | MipiData | Real-time data received after the four lanes corresponding to the PHY detect the MIPI frame synchronization signal                                          |  |  |  |
|                               | LvdsData | Real-time data received after the four lanes corresponding to the PHY detect the LVDS frame synchronization signal                                          |  |  |  |
| MIPI                          | Devno    | MIPI RX device ID                                                                                                                                           |  |  |  |
| DETECT<br>INFO                | VC       | Virtual channel                                                                                                                                             |  |  |  |
| (available only in MIPI mode) | width    | Total width of images detected by the MIPI controller                                                                                                       |  |  |  |
|                               | height   | Total height of images detected by the MIPI controller                                                                                                      |  |  |  |





| Parameter               |            | Description                                                          |  |  |  |
|-------------------------|------------|----------------------------------------------------------------------|--|--|--|
| LVDS                    | Devno      | MIPI RX device ID                                                    |  |  |  |
| DETECT<br>INFO          | VC         | Virtual channel                                                      |  |  |  |
| (available only in LVDS | width      | Total width of images detected by the MIPI controller                |  |  |  |
| mode)                   | height     | Total height of images detected by the MIPI controller               |  |  |  |
| LVDS                    | Devno      | MIPI RX device ID                                                    |  |  |  |
| LANE<br>DETECT          | Lane       | Lane ID                                                              |  |  |  |
| INFO (available         | width      | Image width detected on the lane                                     |  |  |  |
| only in LVDS mode)      | height     | Image height detected on the lane                                    |  |  |  |
| PHY CIL                 | PhyId      | PHY ID                                                               |  |  |  |
| ERR INT<br>INFO         | Clk2TmOut  | Timeout when the lane of clock 2 is switched from LP mode to HS mode |  |  |  |
|                         | ClkTmOut   | Timeout when the lane of clock 1 is switched from LP mode to HS mode |  |  |  |
|                         | Lane0TmOut | Timeout when data lane 0 is switched from LP mode to HS mode         |  |  |  |
|                         | Lane1TmOut | Timeout when data lane 1 is switched from LP mode to HS mode         |  |  |  |
|                         | Lane2TmOut | Timeout when data lane 2 is switched from LP mode to HS mode         |  |  |  |
|                         | Lane3TmOut | Timeout when data lane 3 is switched from LP mode to HS mode         |  |  |  |
|                         | Clk2Esc    | Timeout when the lane of clock 2 is switched to escape mode          |  |  |  |
|                         | ClkEsc     | Timeout when the lane of clock 1 is switched to escape mode          |  |  |  |
|                         | Lane0Esc   | Timeout when data lane 0 is switched to escape mode                  |  |  |  |
|                         | Lane1Esc   | Timeout when data lane 1 is switched to escape mode                  |  |  |  |
|                         | Lane2Esc   | Timeout when data lane 2 is switched to escape mode                  |  |  |  |
|                         | Lane3Esc   | Timeout when data lane 3 is switched to escape mode                  |  |  |  |
| MIPI                    | Devno      | MIPI RX device ID                                                    |  |  |  |





| Parameter                         |              | Description                                                  |  |  |  |
|-----------------------------------|--------------|--------------------------------------------------------------|--|--|--|
| ERROR<br>INT INFO 1<br>(available | Ecc2         | Whether the header has at least two uncorrectable ECC errors |  |  |  |
| only in                           | Vc0CRC       | Count of CRC errors for VC0 data                             |  |  |  |
| MIPI mode)                        | Vc1CRC       | Count of CRC errors for VC1 data                             |  |  |  |
|                                   | Vc2CRC       | Count of CRC errors for VC2 data                             |  |  |  |
|                                   | Vc3CRC       | Count of CRC errors for VC3 data                             |  |  |  |
|                                   | Vc0EccCorrct | Count of the corrected ECC errors for the VC0 header         |  |  |  |
|                                   | Vc1EccCorrct | Count of the corrected ECC errors for the VC1 header         |  |  |  |
|                                   | Vc2EccCorrct | Count of the corrected ECC errors for the VC2 header         |  |  |  |
|                                   | Vc3EccCorrct | Count of the corrected ECC errors for the VC3 header         |  |  |  |
| MIPI                              | Devno        | MIPI RX device ID                                            |  |  |  |
| ERROR<br>INT INFO 2               | Vc0Dt        | Count of data types unsupported by VC0                       |  |  |  |
| (available only in                | Vc1Dt        | Count of data types unsupported by VC1                       |  |  |  |
| MIPI mode)                        | Vc2Dt        | Count of data types unsupported by VC2                       |  |  |  |
|                                   | Vc3Dt        | Count of data types unsupported by VC3                       |  |  |  |
|                                   | Vc0FrmCrc    | Count of frame data errors for VC0                           |  |  |  |
|                                   | Vc1FrmCrc    | Count of frame data errors for VC1                           |  |  |  |
|                                   | Vc2FrmCrc    | Count of frame data errors for VC2                           |  |  |  |
|                                   | Vc3FrmCrc    | Count of frame data errors for VC3                           |  |  |  |
| MIPI                              | Devno        | MIPI RX device ID                                            |  |  |  |
| ERROR<br>INT INFO 3               | Vc0FrmSeq    | Count of frame sequence errors for VC0                       |  |  |  |
| (available only in                | Vc1FrmSeq    | Count of frame sequence errors for VC1                       |  |  |  |
| MIPI mode)                        | Vc2FrmSeq    | Count of frame sequence errors for VC2                       |  |  |  |
|                                   | Vc3FrmSeq    | Count of frame sequence errors for VC3                       |  |  |  |
|                                   | Vc0BndryMt   | Count of short packets with SOF and EOF mismatching for VC0  |  |  |  |
|                                   | Vc1BndryMt   | Count of short packets with SOF and EOF mismatching for VC1  |  |  |  |
|                                   | Vc2BndryMt   | Count of short packets with SOF and EOF mismatching for VC2  |  |  |  |



| Parameter                       |               | Description                                                 |  |  |
|---------------------------------|---------------|-------------------------------------------------------------|--|--|
|                                 | Vc3BndryMt    | Count of short packets with SOF and EOF mismatching for VC3 |  |  |
| MIPI                            | Devno         | MIPI RX device ID                                           |  |  |
| ERROR<br>INT INFO 4             | DataFifoRdErr | Count of MIPI CTRL read data FIFO interrupts                |  |  |
| (available only in MIPI mode)   | CmdFifoRdErr  | Count of MIPI CTRL read command FIFO interrupts             |  |  |
|                                 | CmdFifoWrErr  | Count of MIPI CTRL write command FIFO interrupts            |  |  |
|                                 | DataFifoWrErr | Count of MIPI CTRL write data FIFO interrupts               |  |  |
| LVDS                            | Devno         | MIPI device ID                                              |  |  |
| ERROR<br>INT INFO<br>(available | CmdRdErr      | Count of CMD_FIFO read error interrupts for LVDS            |  |  |
| only in LVDS mode)              | CmdWrErr      | Count of CMD_FIFO write error interrupts for LVDS           |  |  |
|                                 | PopErr        | Count of line_buf read error interrupts for LVDS            |  |  |
|                                 | StatErr       | Count of lane synchronization error interrupts for LVDS     |  |  |
|                                 | Link0WrErr    | Count of FIFO read error interrupts for link 0              |  |  |
|                                 | Link0RdErr    | Count of FIFO write error interrupts for link 0             |  |  |
| ALING                           | Devno         | MIPI device ID                                              |  |  |
| ERROR<br>INFO                   | FIFO_FullErr  | FIFO overflow                                               |  |  |
|                                 | Lane0Err      | Lane 0 FIFO overflow                                        |  |  |
|                                 | Lane1Err      | Lane 1 FIFO overflow                                        |  |  |
|                                 | Lane2Err      | Lane 2 FIFO overflow                                        |  |  |
|                                 | Lane3Err      | Lane 3 FIFO overflow                                        |  |  |

### Hi3516E V200

### [Debugging Information]

```
Module: [MIPI_RX], Build Time[Nov 24 2018, 14:50:01]

----MIPI LANE DIVIDE MODE----

MODE LANE DIVIDE

0 2

----MIPI DEV ATTR-----

Devno WorkMode DataRate DataType WDRMode ImgX ImgY
```

| ImgW Im    | gH          |           |          |          |            |        |        |       |
|------------|-------------|-----------|----------|----------|------------|--------|--------|-------|
| 0          | MIPI        | X1        |          | RAW12    | None       | 0      | 204    | 2304  |
| 1296       |             |           |          |          |            |        |        |       |
|            |             |           |          |          |            |        |        |       |
| MIPI       | LANE INFO-  |           |          |          |            |        |        |       |
| Devno      |             | LaneID    |          |          |            |        |        |       |
| 0          |             | 0, 1,     |          |          |            |        |        |       |
|            |             |           |          |          |            |        |        |       |
| MIPI       | PHY DATA I  | NFO       |          |          |            |        |        |       |
|            | Lanel       |           |          |          | Mipi       |        |        |       |
| LvdsData   |             |           | -        |          | -          |        |        |       |
| 0          | 0, 1        | 0x00,0x00 | 0x36,    | 0x2b 0x  | 9b,0x1ad27 | 5      |        |       |
|            | DETECT INE  |           |          |          |            |        |        |       |
|            | width he    |           |          |          |            |        |        |       |
|            | 2304 1      | -         |          |          |            |        |        |       |
| 0 1        | 0           | 0         |          |          |            |        |        |       |
| LVDS       | DETECT INE  | ·O        |          |          |            |        |        |       |
|            | width he    |           |          |          |            |        |        |       |
|            | 2304        | _         |          |          |            |        |        |       |
|            | 0           |           |          |          |            |        |        |       |
| LVDS       | LANE DETEC  | T INFO    |          |          |            |        |        |       |
|            |             |           |          |          |            |        |        |       |
| Devno La   | ne width    | height    |          |          |            |        |        |       |
| 0          | 0 0         | 0         |          |          |            |        |        |       |
| 0          | 1 0         | 0         |          |          |            |        |        |       |
| PHY (      | CIL ERR INT | INFO      |          |          |            |        |        |       |
| PhyId (    | Clk2TmOut   | ClkTmOut  | Lane0Tm( | Out Lane | 1TmOut La  | ne2Tm( | Out    |       |
| Lane3TmOut | Clk2Esc     | ClkEsc L  | ane0Esc  | Lane1Eso | c Lane2Esc | Lane   | e3Esc  |       |
| 0          | 0           | 0         | 0        | 0        | 0          | )      | 0      | 0     |
| 0 0        | 0           | 0         | 0        |          |            |        |        |       |
| MIPI       | ERROR INT   | INFO 1    |          |          |            |        |        |       |
| Devno I    | Ecc2 Vc0CR  | C Vc1CRC  | Vc2CRC   | Vc3CRC   | Vc0EccCori | rct V  | c1EccC | orrct |
| Vc2EccCori | ct Vc3Ecc   | Corrct    |          |          |            |        |        |       |
| 0          | 0 0         | 0         | 0        | 0        | 0          |        | 0      |       |
| 0          | 0           |           |          |          |            |        |        |       |
|            |             |           |          |          |            |        |        |       |
| MIPI       | ERROR INT   | INFO 2    |          |          |            |        |        |       |
| Devno V    | Vc0Dt Vc1D  | t Vc2Dt   | Vc3Dt V  | c0FrmCrc | Vc1FrmCr   | c Vc2  | FrmCrc |       |
| Vc3FrmCrc  |             |           |          |          |            |        |        |       |
| 0          | 0 0         | 0         | 0        | 0        | 0          | 0      |        | 0     |
|            |             |           |          |          |            |        |        |       |
| MIPI       | ERROR INT   | INFO 3    |          |          |            |        |        |       |
| Devno V    | /c0FrmSeq   | Vc1FrmSeq | Vc2Frm3  | Seq Vc3F | rmSeq Vc0  | BndryN | 1t     |       |
| Vc1BndryMt | Vc2Bndry    | Mt Vc3Bnd | lryMt    |          |            |        |        |       |





#### [Analysis]

- The MIPI RX receives differential data of the sensor by using the PHY. After detecting the sync header, the PHY controller aligns data in each lane.
- The pixel controller parses sync information and merges data in the lane into pixel data based on the bit width of raw data. It transmits pixel data to the downstream module in output mode.
- The PHY, PHY controller, and pixel controller use the pixel clock of the sensor. The clock of the output module is the associated clock, which is the same as the working clock of the downstream module. The crop function of the MIPI RX is implemented at the end of the pixel controller. Therefore, the required associated clock can be reduced after cropping.

Figure 1-6 MIPI data stream



[Parameter Description]





| Parameter              |             | Description                                                                                                       |
|------------------------|-------------|-------------------------------------------------------------------------------------------------------------------|
| MIPI                   | MODE        | Lane distribution mode of the MIPI RX                                                                             |
| LANE<br>DIVIDE<br>MODE | LANE DIVIDE | Detailed lane distribution of the MIPI RX                                                                         |
| MIPI DEV               | Devno       | MIPI device ID                                                                                                    |
| ATTR                   | WorkMode    | Working mode of the MIPI device  LVDS  MIPI  CMOS                                                                 |
|                        | DataRate    | MIPI RX rate                                                                                                      |
|                        | DataType    | Data type  • 8-bit raw data  • 10-bit raw data  • 12-bit raw data  • 14-bit raw data  • 16-bit raw data           |
|                        | WDRMode     | WDR mode  None: non-WDR mode  2To1: 2-to-1WDR  DOL2To1: DOL 2-to-1WDR                                             |
|                        | ImgX        | Horizontal coordinate of the cropped image                                                                        |
|                        | ImgY        | Vertical coordinate of the cropped image                                                                          |
|                        | ImgW        | Width of the cropped image                                                                                        |
|                        | ImgH        | Height of the cropped image                                                                                       |
| MIPI                   | Devno       | MIPI device ID                                                                                                    |
| LANE<br>INFO           | LaneID      | Lane ID                                                                                                           |
| MIPI PHY               | PhyId       | PHY ID                                                                                                            |
| DATA<br>INFO           | LaneId      | Lane ID                                                                                                           |
|                        | PhyData     | Real-time data received by the two lanes corresponding to the PHY                                                 |
|                        | MipiData    | Real-time data received after the two lanes corresponding to the PHY detect the MIPI frame synchronization signal |
|                        | LvdsData    | Real-time data received after the two lanes corresponding to the PHY detect the LVDS frame synchronization signal |





| Parameter                                                     |            | Description                                                          |
|---------------------------------------------------------------|------------|----------------------------------------------------------------------|
| MIPI<br>DETECT<br>INFO<br>(available<br>only in<br>MIPI mode) | Devno      | MIPI RX device ID                                                    |
|                                                               | VC         | Virtual channel                                                      |
|                                                               | width      | Total width of images detected by the MIPI controller                |
|                                                               | height     | Total height of images detected by the MIPI controller               |
| LVDS                                                          | Devno      | MIPI RX device ID                                                    |
| DETECT<br>INFO                                                | VC         | Virtual channel                                                      |
| (available<br>only in<br>LVDS<br>mode)                        | width      | Total width of images detected by the MIPI controller                |
|                                                               | height     | Total height of images detected by the MIPI controller               |
| LVDS                                                          | Devno      | MIPI RX device ID                                                    |
| LANE<br>DETECT                                                | Lane       | Lane ID                                                              |
| INFO<br>(available                                            | width      | Image width detected on the lane                                     |
| only in LVDS mode)                                            | height     | Image height detected on the lane                                    |
| PHY CIL                                                       | PhyId      | PHY ID                                                               |
| ERR INT<br>INFO                                               | Clk2TmOut  | Timeout when the lane of clock 2 is switched from LP mode to HS mode |
|                                                               | ClkTmOut   | Timeout when the lane of clock 1 is switched from LP mode to HS mode |
|                                                               | Lane0TmOut | Timeout when data lane 0 is switched from LP mode to HS mode         |
|                                                               | Lane1TmOut | Timeout when data lane 1 is switched from LP mode to HS mode         |
|                                                               | Clk2Esc    | Timeout when the lane of clock 2 is switched to escape mode          |
|                                                               | ClkEsc     | Timeout when the lane of clock 1 is switched to escape mode          |
|                                                               | Lane0Esc   | Timeout when data lane 0 is switched to escape mode                  |
|                                                               | Lane1Esc   | Timeout when data lane 1 is switched to escape mode                  |
| MIPI                                                          | Devno      | MIPI RX device ID                                                    |





| Parameter                                                     |               | Description                                                  |
|---------------------------------------------------------------|---------------|--------------------------------------------------------------|
| ERROR<br>INT INFO 1<br>(available<br>only in<br>MIPI mode)    | Ecc2          | Whether the header has at least two uncorrectable ECC errors |
|                                                               | Vc0CRC        | Count of CRC errors for VC0 data                             |
|                                                               | Vc1CRC        | Count of CRC errors for VC1 data                             |
|                                                               | Vc0EccCorret  | Count of the corrected ECC errors for the VC0 header         |
|                                                               | Vc1EccCorret  | Count of the corrected ECC errors for the VC1 header         |
| MIPI                                                          | Devno         | MIPI RX device ID                                            |
| ERROR<br>INT INFO 2                                           | Vc0Dt         | Count of data types unsupported by VC0                       |
| (available only in                                            | Vc1Dt         | Count of data types unsupported by VC1                       |
| MIPI mode)                                                    | Vc0FrmCrc     | Count of frame data errors for VC0                           |
|                                                               | Vc1FrmCrc     | Count of frame data errors for VC1                           |
| MIPI                                                          | Devno         | MIPI RX device ID                                            |
| ERROR<br>INT INFO 3                                           | Vc0FrmSeq     | Count of frame sequence errors for VC0                       |
| (available only in                                            | Vc1FrmSeq     | Count of frame sequence errors for VC1                       |
| MIPI mode)                                                    | Vc0BndryMt    | Count of short packets with SOF and EOF mismatching for VC0  |
|                                                               | Vc1BndryMt    | Count of short packets with SOF and EOF mismatching for VC1  |
| MIPI                                                          | Devno         | MIPI RX device ID                                            |
| ERROR<br>INT INFO 4                                           | DataFifoRdErr | Count of MIPI CTRL read data FIFO interrupts                 |
| (available only in MIPI mode)                                 | CmdFifoRdErr  | Count of MIPI CTRL read command FIFO interrupts              |
|                                                               | Vsync         | Count of MIPI CTR VSync interrupts                           |
|                                                               | CmdFifoWrErr  | Count of MIPI CTRL write command FIFO interrupts             |
|                                                               | DataFifoWrErr | Count of MIPI CTRL write data FIFO interrupts                |
| LVDS                                                          | Devno         | MIPI device ID                                               |
| ERROR<br>INT INFO 1<br>(available<br>only in<br>LVDS<br>mode) | Vsync         | Count of VSync interrupts for LVDS                           |
|                                                               | CmdRdErr      | Count of CMD_FIFO read error interrupts for LVDS             |
|                                                               | CmdWrErr      | Count of CMD_FIFO write error interrupts for LVDS            |



| Parameter           |              | Description                                             |
|---------------------|--------------|---------------------------------------------------------|
|                     | PopErr       | Count of line_buf read error interrupts for LVDS        |
|                     | StatErr      | Count of lane synchronization error interrupts for LVDS |
| LVDS                | Devno        | MIPI device ID                                          |
| ERROR<br>INT INFO 2 | Link0WrErr   | Count of FIFO read error interrupts for link 0          |
| (available only in  | Link1WrErr   | Count of FIFO read error interrupts for link 1          |
| LVDS                | Link0RdErr   | Count of FIFO write error interrupts for link 0         |
| mode)               | Link1RdErr   | Count of FIFO write error interrupts for link 1         |
| ALING               | Devno        | MIPI device ID                                          |
| ERROR<br>INFO       | FIFO_FullErr | FIFO overflow                                           |
|                     | Lane0Err     | Lane 0 FIFO overflow                                    |
|                     | Lane1Err     | Lane 1 FIFO overflow                                    |

# 1.7.2 MIPI\_TX Proc Information

# NOTICE

The MIPI\_TX proc information is applicable to Hi3559A V100, Hi3519A V100, and Hi3516C V500.

The proc information of the MIPI TX includes the configuration information, timing configuration information, and status information of the MIPI TX.

#### [Debugging Information]

```
Module: [MIPI_TX], Build Time[Jun 21 2018, 15:23:45]
-----MIPI Tx DEV CONFIG-----
 devno lane0 lane1 lane2 lane3 output_mode phy_data_rate
pixel clk(KHz) video mode output fmt
   0 0 1 2
                     3 1 945 148500
-----MIPI_Tx SYNC CONFIG-----
   pkt_size hsa_pixels hbp_pixels hline_pixels vsa_lines
vbp_lines vfp_lines active_lines edpi_cmd_size
    1080
              8
                      20
                                       10
                                                26
      1920
16
                0
-----MIPI Tx DEV STATUS------
```



width height HoriAll VertAll hbp hsa vsa 1080 1920 1237 1972 20 8 10

### [Analysis]

Proc information such as MIPI TX device configuration information and MIPI TX timing configuration information is configured through the interface before the device starts. The MIPI TX device status information is part of the timing information detected during device running, which includes the valid width and height, total horizontal width, and total vertical height.

#### [Parameter Description]

| Parameter      |                                  | Description                                                                                                                                                                        |
|----------------|----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MIPI_Tx        | devno                            | Device ID                                                                                                                                                                          |
| DEV<br>CONFIG  | lane0<br>lane1<br>lane2<br>lane3 | ≥ 0: lane ID<br>-1: disabled                                                                                                                                                       |
|                | output_mode                      | 0: CSI mode 1: DSI video mode 2: DSI command mode                                                                                                                                  |
|                | phy_data_rate                    | PHY data rate                                                                                                                                                                      |
|                | pixel_clk(KHz)                   | Pixel clock, in KHz                                                                                                                                                                |
|                | video_mode                       | 0: BURST_MODE 1: NON_BURST_MODE_SYNC_PULSES 2: NON_BURST_MODE_SYNC_EVENTS                                                                                                          |
|                | output_fmt                       | 0:OUT_FORMAT_RGB_16_BIT<br>1:OUT_FORMAT_RGB_18_BIT<br>2:OUT_FORMAT_RGB_24_BIT<br>3:OUT_FORMAT_YUV420_8_BIT_NORMAL<br>4:OUT_FORMAT_YUV420_8_BIT_LEGACY<br>5:OUT_FORMAT_YUV422_8_BIT |
| MIPI_Tx        | pkt_size                         | hact                                                                                                                                                                               |
| SYNC<br>CONFIG | hsa_pixels                       | hsync                                                                                                                                                                              |
|                | hbp_pixels                       | hbp                                                                                                                                                                                |
|                | hline_pixels                     | hact+hsa+hbp+hfp                                                                                                                                                                   |
|                | vsa_lines                        | vsa                                                                                                                                                                                |
|                | vbp_lines                        | vbp                                                                                                                                                                                |
|                | vfp_lines                        | vfp                                                                                                                                                                                |



| Parameter     |               | Description                      |
|---------------|---------------|----------------------------------|
|               | active_lines  | vact                             |
|               | edpi_cmd_size | edpi cmd size                    |
| MIPI_Tx       | width         | Detected width                   |
| DEV<br>STATUS | height        | Detected width                   |
|               | HoriAll       | Total horizontal width           |
|               | VertAll       | Total vertical height            |
|               | hbp           | Horizontal front porch           |
|               | hsa           | Number of horizontal sync pulses |
|               | vsa           | Number of vertical sync pulses   |

# **1.8 FAQs**

For details about the Hi3559A V100ES MIPI specifications, see the *Hi35xx Vxxx ultra-HD Mobile Camera SoC Data Sheet* and *Features of the Video Interfaces of HiSilicon IP Cameras*.

# 1.8.1 How Do I Configure a Lane ID?

The lane ID corresponds to **short lane\_id[MIPI\_LANE\_NUM]** in mipi\_dev\_attr\_t or **short lane\_id[SLVS\_LANE\_NUM]** in slvs\_dev\_attr\_t. The index number of the lane\_id array indicates the sensor lane ID, and the value of the lane\_id array the MIPI lane ID.

Set lane\_id of unused lanes to -1 when the MIPI connects to the sensor. You can also adjust the data channel sequence by configuring lane-id based on the hardware board and actual sensor output channels.

Table 1-7 shows an example for pin hardware connection between the MIPI and the sensor.

Table 1-7 Mapping between the sensor and MIPI RX pins

| MIPI Lane Pins | Sensor Lane Pins |
|----------------|------------------|
| MIPI_RX1_D0    | Lane 0           |
| MIPI_RX1_D1    | Lane 1           |
| MIPI_RX1_D2    | Lane 2           |
| MIPI_RX1_D3    | Lane 3           |

The MIPI has a maximum number of eight lanes. It is supposed that the sensor also has up to eight lanes. Because there are actually four sensor lanes that transmit data to four MIPI lanes, it requires that the IDs of sensor unconnected lanes or nonexistent lanes are set to **-1**. lane\_id is configured as follows:





# 1.8.2 What Is the Relationship Between the MIPI Lane Frequency and VI Frequency?

When multiple MIPI lanes are used for data transfer, what is the relationship between the transfer frequency of MIPI lanes and VI processing frequency, and how do I calculate the maximum transfer frequency of each lane?

- The MIPI RX receives data from multiple lanes, converts data into the internal timing, and transmits the timing to the video input unit (VIU) for processing. The total amount of data transferred by multiple lanes remains unchanged, as described in the following equation:
  - VI\_Freq x Pix\_Width = Lane\_Num x MIPI\_Freq
- Where VI\_Freq indicates the frequency of the VI working clock, Pix\_Width indicates
  the pixel bit width, Lane\_Num indicates the number of lanes used for data transfer, and
  MIPI Freq indicates the maximum RX frequency of each lane.
- MIPI\_Freq is calculated as follows: MIPI\_Freq = (VI\_Freq x Pix\_Width)/Lane\_Num. For example, if the frequency of the VI working clock is 250 MHz, the MIPI data is in RAW12 format, and four lanes are used for data transfer, MIPI\_Freq is calculated as follows:

MIPI\_Freq = 
$$(250 \times 12)/4 = 750$$

That is, the maximum transfer frequency of each lane is 750 MHz.